MySQL数据库Data too long for column问题以及无法存储中文问题,CMD窗口显示中文乱码问题,my.ini修改“default-character-set=”无效问题
直接开始解决问题首先,Data too long for column问题以及无法存储中文问题,如果字段长度设置得保证是足够的,那么一般情况下都是 数据库字符集引发的问题首先登录上mysql 数据库 ,输入show variables like '%charac%';#查看数据库字符集如果返回的是Empty set,那么输入install plugin validate_password sona
花了一个下午的时间,看了网上很多说法,都是修改 my.ini 配置文件,但是我的情况比较神奇,修改了之后还是没有用,于是我就看到 client 这个单词,我就在想是不是在访问数据库的时候,配置文件的某些配置被覆盖掉了,导致修改 my.ini 配置文件无效,结构我就试了一下,还真解决了这个问题。
直接开始解决问题,这个问题分为两部分
- 配置my.ini文件
- 解决cmd窗口中文乱码
首先,Data too long for column问题以及无法存储中文问题,如果字段长度设置得保证是足够的,那么一般情况下都是 数据库字符集引发的问题
首先登录上 mysql 数据库 ,输入
show variables like '%charac%';
#查看数据库字符集
如果返回的是Empty set,那么输入
install plugin validate_password soname 'validate_password.dll';
#安装 validate_password 插件
安装成功之后再重新输入第一段代码
如果情况正常得到的会是这样一个表格
对于表格的解读:
- character_set_client
- character_set_connection
- character_set_results
以上三个控制mysql client的字符集
- character_set_database
设置数据库的默认字符集
- character_set_server
设置以上所有的默认字符集
想要显示中文我们只需要将,除 character_set_fliesystem ,character_set_system 和character_set_dir 以外的设置为 utf8 即可。
找到 my.ini 文件,在 [client] 和 [mysql] 标签下分别加入
default-character-set=utf8
如图:


保存后,重启mysql服务,建议手动重启,不要使用cmd命令,因为每个人的服务名可能不同,具体重启步骤很简单,自己百度吧,这里略过
如果重启后再次登录数据库,使用show variables like '%charac%'; 语句显示如下,或者都是utf8,那么恭喜你已经成功了

但是如果像我刚开始说的一样的(配置了my.ini文件无效),那么不急,我们在来解决第二个问题
解决cmd显示中文乱码,解决了这个问题之后,我就可以在数据中添加中文和显示中文了,(很有可能是在用cmd访问mysql时,cmd本身的编码格式覆盖了my.ini配置的属性,这是我猜的,没有明确证据)
于是我们只要设置cmd窗口的编码为 utf8 即可。
永久有效方法如下:
- 按win + R ,输入 regedit 进入注册表
- 找到该路径:计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Command Processor
- 右键点击文件夹,选择新建 -> 字符串值,名称输入 autorun ,数据输入 chcp 65001(有空格)
关闭注册表,重新启动 mysql 服务,重新操作如上

得到的表就是这样的了,即便重新打开cmd窗口也不会改变

本人亲测有效的方法,如果有更好的方法,欢迎评论指正
DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。
更多推荐


所有评论(0)