Mysql 5.59在windows10下乱码解决方式

1、安装完mysql,在dos登陆mysql,然后建表并插入中文数据,在dos执行查询显示乱码:

      

2、网上查询相关资料,是mysql得my.ini没有配置相关编码,执行【show variables like "%char%";】

     如下所示,明显character_set_database编码位latin1(其实就是ISO-8859-1),而客户端访问和链接

     都是gbk编码

      

  3、修改my.ini, 在my.ini得[mysqld]下增加character-set-server=utf8,重新启动mysql,再次

       重新建表再插入中文数据,编码正常。重新执行命令【show variables like "%char%";】,发

       现character_set_database和character_set_server由latin1变为了utf8

       

   4、扩展&思考

        1)为啥在my.ini中改了 character-set-server=utf8,character_set_database和character_set_server

             会变?这个从代码角度来说应该容易理解,代码读到my.ini发现这个character-set-server有值,就将

             character_set_database和character_set_server得默认值设置为相同,说明character-set-server优

              先级还比较高,怎么感觉等于没说!

       2)上面都是用dos登陆,装个客户端 “Navicat for mysql”,重新执行show VARIABLES like                

            "%char%",发现红色标记几个参数明显和dos登陆不一样,这只能说明客户端和连接方式得编码格式

              右客户端决定的, 而不是mysql服务端启动决定,应该是客户端启动的时候就传入默认参数了。

               

       3) utf8、gb2312,ISO-8859-1、asicll等等编码具体是怎么编码的,为啥互相转换会出现乱码,

             这个值得进一步研究,该篇文章暂不做探讨。


             

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值