工程人才招聘网,宁波seo外包引流推广,做一个美食网站怎么做,网络营销软文范例300字问题发生的原委
之前在项目开发的时候#xff0c;我本地也建立了数据库用作开发库#xff0c;我本地的数据库版本是5.7的#xff0c;但是测试和生产库都是8.0的版本#xff0c;我们定义的数据库字符集是utf8mb4#xff0c;排序规则是utf8mb4_general_ci#xff0c;前段时…问题发生的原委
之前在项目开发的时候我本地也建立了数据库用作开发库我本地的数据库版本是5.7的但是测试和生产库都是8.0的版本我们定义的数据库字符集是utf8mb4排序规则是utf8mb4_general_ci前段时间一直都没有什么问题直到有一天发测试的时候有个sql语句报错了我这里是在连接查询的时候报错的错误信息为(utf8mb4_general_ci,IMPLICIT)and (utf8mb4_0900_ai_ciMysql...大致意思是作为连接条件的A和B字段的排序规则不同导致的由于我在测试数据库建表的时候设定的排序规则是utf8mb4_general_ci但是测试服是8.0版本以上的默认的排序规则是utf8mb4_0900_ai_ci所以导致连接查询的时候出错误了这里需要更改建表时的字段的排序规则为utf8mb4_0900_ai_ci或者更改数据库实例的默认排序规则为utf8mb4_general_ci。
解决方式和教训
千万记住以后建表时统一规则规定的什么字符集和排序规则就用什么字符集和排序规则不要A表使用utf8然后B表使用latin等…这样后面连接查询可能会出现问题并且无法使用到索引修改还很麻烦
对于MySQL5.7版本 建议建表时字符集设置为utf8mb4排序规则设置为utf8mb4_general_ci因为5.7版本的数据库实例默认排序规则就是utf8mb4_general_ci所以会方便很多也没什么问题
#设置数据库字符集和排序规则
alter database database default character set utf8mb4 COLLATE utf8mb4_general_ci;
# 配置字符集/*数据库客户端的编码*/set character_set_client utf8mb4;/*建立连接使用的编码*/set character_set_connection utf8mb4;/*数据库的编码*/set character_set_database utf8mb4;/*结果集的编码*/set character_set_results utf8mb4;/*数据库服务器的编码*/set character_set_serverutf8mb4;对于MySQL8.0版本 建议建表时字符集设置为utf8mb4排序规则设置为utf8mb4_0900_ai_ci因为8.0版本的数据库实例默认排序规则就是utf8mb4_0900_ai_ci
#设置数据库字符集和排序规则
alter database database default character set utf8mb4 COLLATE utf8mb4_0900_ai_ci;
# 配置字符集/*数据库客户端的编码*/set character_set_client utf8mb4;/*建立连接使用的编码*/set character_set_connection utf8mb4;/*数据库的编码*/set character_set_database utf8mb4;/*结果集的编码*/set character_set_results utf8mb4;/*数据库服务器的编码*/set character_set_serverutf8mb4;如果像我一样在MySQL8.0实例上的数据库统一使用5.7的标准也就是字符集设置为utf8mb4排序规则设置为utf8mb4_general_ci那么请执行以下语句不建议在8.0上使用5.7的标准不知道还有啥坑 字符集统一设定为utf8mb4 对于已经建好的表来说那么需要修改其中的字段的字符集和表的排序规则 参考该博客批量修改MySQL的字符集、排序规则以及保证默认值不会发生修改 设定排序规则为utf8mb4_general_ci
#设置数据库级别默认排序规则和以后建表的默认字符集
alter database database default character set utf8mb4 COLLATE utf8mb4_general_ci;
# 设置会话级别排序规则(默认排序规则)
set session default_collation_for_utf8mb4 utf8mb4_general_ci;
#设置连接级别排序规则
set collation_connection utf8mb4_general_ci;
#设置全局级别
set global default_collation_for_utf8mb4 utf8mb4_general_ci;#设置完查看是否正确
show VARIABLES WHERE Variable_name LIKE character\_set\_% OR Variable_name LIKE collation%;
show VARIABLES WHERE value LIKE utf8%;
#上面的show语句的结果可以不用关注【character_set_system】和【collation_server】基本不影响参考博客
mysql 8.0设置collation_connection MySQL Variables collation_connection 数据库 参数变量解释及正确配置使用 Mysql8查询字符串查询异常 mysql8.0导数时表字符集的的COLLATE总是utf8mb4_0900_ai_ci MySQL字符集及其排序规则 mysql collation设置