mysql字节乱码问题之解决方法

本文介绍了解决MySQL字符集导致的乱码问题的方法。包括安装时更改默认编码为utf8,修改my.ini文件中的default-character-set属性,以及解释为何需要将客户端设置为GBK编码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库字符集问题会导致乱码,从而消耗开发者蛮多精力。针对mysql的用户,按如下AB所示的方法操作,即可避免大部编码问题

A.mysql安装时的默认编码是latin1,此时要注意需要将其手动更改为utf8.

B. 修改my.ini文件

My.ini中的[mysql]对应的是客户端参数

    [mysqld]中对应的刚是数据库后台服务的相关参数

   两者都有default-character-set属性,将client端设置为GBK编码,后台数据用utf8存储,可以满足大部国内开发者的开发环境需求。

 

补充说明1.

对于“将client端设置为GBK编码”的补充说明

目前Windows的内核已经支持Unicode字符集,内核上可以支持全世界所有的语言文字,同时用Windows使用代码页(codepage)来适应各个国家和地区。codepage可以理解为我们在普通的cmd窗口或文本编辑器中输入文字时的默认编码。这也是数据库客户端的显示编码字符集必须与my.ini设置一致的原因,如果将utf8编码在cp936表中进行查找,势必得到乱码。

GBK对应的codepage是CP936。

查看方法为cmd->chcp,如下图结果,可以确认客户端默认输入编码为936

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值