MySQL数据库Data too long for column问题以及无法存储中文问题,CMD窗口显示中文乱码问题,my.ini修改“default-character-set=”无效问题

本文介绍了如何解决MySQL数据库中文乱码问题和CMD窗口显示中文乱码的问题。通过调整my.ini配置文件,设置字符集为utf8,并在注册表中设置CMD窗口编码为UTF-8,实现了中文正常显示。同时,提供了详细的操作步骤和截图说明。
摘要由CSDN通过智能技术生成

花了一个下午的时间,看了网上很多说法,都是修改 my.ini 配置文件,但是我的情况比较神奇,修改了之后还是没有用,于是我就看到 client 这个单词,我就在想是不是在访问数据库的时候,配置文件的某些配置被覆盖掉了,导致修改 my.ini 配置文件无效,结构我就试了一下,还真解决了这个问题。

直接开始解决问题,这个问题分为两部分

  1. 配置my.ini文件
  2. 解决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 即可。

永久有效方法如下:

  1. 按win + R ,输入 regedit 进入注册表
  2. 找到该路径:计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Command Processor
  3. 右键点击文件夹,选择新建 -> 字符串值,名称输入 autorun ,数据输入 chcp 65001(有空格)

关闭注册表,重新启动 mysql 服务,重新操作如上

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

本人亲测有效的方法,如果有更好的方法,欢迎评论指正 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值