2024年6月14日排查问题简单记录

公司线上环境报错了,看报错是排序规则对于编码无效。

代码建表语句是之前交接的人写的。

其实正常情况表的编码和排序规则都是会统一指定的。

先问一下团队这方面的规范是什么,然后去查看一下相关的应该怎么查看怎么更改的知识。

关于mysql编码的一些文档。

https://dev.mysql.com/doc/refman/5.7/en/alter-table.html

https://dev.mysql.com/doc/refman/5.7/en/charset-table.html

https://dev.mysql.com/doc/refman/5.7/en/charset-unicode.html

https://dev.mysql.com/doc/refman/5.7/en/charset-unicode-utf8mb3.html

中文方面的文档

https://www.docs4dev.com/docs/zh/mysql/5.7/reference/charset-unicode-utf8mb3.html

https://mysql.net.cn/doc/refman/8.0/en/charset-mysql.html

sql 复制代码
show create table table_name; -- 查看表结构(给出的是建表的语句)
select version(); -- 查看mysql的版本
show table status;  -- 查看collation列
select * from table_name;
from information_schema.`TABLES`
WHERE 
    table_schema='database_name'
    and `table_name`='table_name';

-- 修改表的编码
alter table `table_name` convert to character set 
utf8mb4 collate utf8mb4_bin;

-- 查看mysql支持的版本,加上筛选
show collation where charset='utf8';

show full columns from `table_name`; -- 查看各个字段的编码
ALTER TABLE tbl_name CHANGE [COLUMN] old_col_name new_col_name column_definition;
-- 其中column_definition这里就可以写更改后的编码和排序规则,例如
ALTER TABLE tbl_name CHANGE [COLUMN] old_col_name new_col_name charset utf8mb4 collate utf8mb4_bin 加其它原本的字段定义;
-- 也可以使用modify子句
ALTER TABLE table_name MODIFY column_name column_definition CHARACTER SET new_charset;

collation是排序规则,通过collation是可以确定编码集(charset)是什么的。所以上面的查看方法,大多都是只能看到utf8_bin之类的collation列,而看不到charset列。

发现测试环境的是8.0而正式环境的是5.7. ps:em,的确有点混乱了。

utf8mb3和utf8在mysql中其实是一回事。实际观察mysql来讲。

测试环境的8.0中collation显示的是utf8mb3,而正式环境的mysql 5.7.29-log版本中,显示的是utf.

因为正式环境和测试环境的版本不一致,测试环境没能测出来。

优先级是符合一般认知的,数据库层面可以设置,表层面可以设置,字段还可以指定。小的层面的设置是优先级更高的呀。

数据库连接的时候可以指定。

首先问团队正式库怎么查看,连上去之后查表、字段的编码设置。

然后问团队,服务启动的初始化配置文件怎么查看,去看初始化的配置的sql的DSN里的相关配置。

进行了相应的更改和确认,但是报错没有变化,还是有问题。

再询问团队的人正式环境的日志该如何查看。

后来看日志发现是生成的sql语句就指定了编码。

再在代码中追溯。发现ent框架的ContainsFold有个坑点,它直接预设编码是utfmb4,然后生成的sql会自动加上 COLLATE utf8mb4_general_ci.

如果实际的编码不是utfmb4,则会报错排序规则对于xxx编码无效的错误。

不过现在一想,不一定是仅仅是版本差异导致测试环境正常,还有可能是测试环境的数据没有中文,可能仅仅是英文的情况下,其实加了utf8mb4_general_ci语句也能执行,不会报错出来。

go 复制代码
		switch b.dialect {
		case dialect.MySQL:
			// We assume the CHARACTER SET is configured to utf8mb4,
			// because this how it is defined in dialect/sql/schema.
			b.Ident(col).WriteString(" COLLATE utf8mb4_general_ci LIKE ")
			b.Arg("%" + strings.ToLower(w) + "%")
        // ...
        }
相关推荐
贝多芬也爱敲代码11 分钟前
如何减小ES和mysql的同步时间差
大数据·mysql·elasticsearch
安当加密1 小时前
MySQL数据库透明加密(TDE)解决方案:基于国密SM4的合规与性能优化实践
数据库·mysql·性能优化
007php0071 小时前
某大厂跳动面试:计算机网络相关问题解析与总结
java·开发语言·学习·计算机网络·mysql·面试·职场和发展
JH30732 小时前
第七篇:Buffer Pool 与 InnoDB 其他组件的协作
java·数据库·mysql·oracle
阿沁QWQ3 小时前
MySQL服务器配置与管理
服务器·数据库·mysql
程序新视界4 小时前
MySQL“索引失效”的隐形杀手:隐式类型转换,你了解多少?
数据库·mysql·dba
XYiFfang5 小时前
【MYSQL】SQL学习指南:从常见错误到高级函数与正则表达式
sql·mysql·正则表达式·regexp_like·group_concat
叫我龙翔5 小时前
【MySQL】从零开始了解数据库开发 --- 数据表的约束
android·c++·mysql·数据库开发
流烟默6 小时前
MySQL索引调优之索引顺序必须和字段顺序一致吗?
mysql·索引调优
我是Superman丶7 小时前
【优化】Mysql指定索引查询或忽略某个索引
数据库·mysql