当前位置: 首页 > news >正文

h5微信网站建设钢琴室内设计效果图

h5微信网站建设,钢琴室内设计效果图,专门做中文音译歌曲的网站,wordpress修改成中文字体问题发生的原委 之前在项目开发的时候,我本地也建立了数据库用作开发库,我本地的数据库版本是5.7的,但是测试和生产库都是8.0的版本,我们定义的数据库字符集是utf8mb4,排序规则是utf8mb4_general_ci,前段时…

问题发生的原委

之前在项目开发的时候,我本地也建立了数据库用作开发库,我本地的数据库版本是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_server=utf8mb4;
  • 对于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_server=utf8mb4;

如果像我一样,在MySQL8.0实例上的数据库统一使用5.7的标准,也就是字符集设置为utf8mb4,排序规则设置为utf8mb4_general_ci,那么请执行以下语句(不建议在8.0上使用5.7的标准,不知道还有啥坑)

  1. 字符集统一设定为utf8mb4
    对于已经建好的表来说,那么需要修改其中的字段的字符集和表的排序规则
    参考该博客批量修改MySQL的字符集、排序规则以及保证默认值不会发生修改

  2. 设定排序规则为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设置

http://www.yayakq.cn/news/284879/

相关文章:

  • 网站开发有关书籍外贸网站电子建设
  • 优化一个网站多少钱做网站用虚拟机还是服务器
  • 文档阅读网站模板下载青岛美工网页设计
  • 游戏开发网站开发自己怎么注册公司网站流程
  • 怎么把几个网站做互通凡科轻站官网
  • ps临摹图片做网站的图片犯法吗seo任务优化网站排名
  • 东莞建筑建设网站建设代理招生平台
  • 建设一个人才网站需要的人才如何做好网站的优化
  • iis7架设网站教程企业网站手机版
  • 怎么识别一个网站怎样自己做公司网站
  • 游戏ui素材网站wordpress 当前页面
  • 在建设厅网站怎么办建造师延期贵阳网络营销推广公司
  • 服务器怎么装网站吗外贸做什么产品出口好
  • 品牌网站建设 磐石网络的确好电子商务网站建设与管理第二版答案
  • 对网站建设的维护期货交易网站开发
  • 度假区网站建设方案芮城做网站的机构
  • 网站建设平面要多少分辨率seo服务的三种方式
  • 上杭县住房和城乡建设局网站电子商务网站设计成功的要素
  • 网店代运营网青岛seo整站优化招商电话
  • 建设网站有哪些参考文献设计网名字
  • 企业网站建设的主要内容网络维修电话
  • 做面食专业网站优创意设计平台
  • 免费个人网站建站申请商城网站制作深圳网站制作
  • 做高仿表网站安徽津城建设工程有限公司网站
  • 傻瓜式网页制作网站个人站长怎么做企业网站
  • 解析域名后怎么弄网站企业网站建设一般原则
  • 档案网站建设的步骤263企业邮箱官网登录
  • 手机端自适应网站布局互联网商城建设
  • 门户网站建设方案文档甘肃网络推广软件
  • 重庆建站模板云南建设投资集团网站首页