Mysql数据库不能插入中文为什么儿啊?

已举报 回答 关注

Mysql数据库不能插入中文为什么儿啊?

  • 回答数

    9

  • 浏览数

    8,086

9个回答 默认排序
  • 默认排序
  • 按时间排序

已采纳
A. 字符编码:

“使用命令行方式登陆到MySQL服务器, 建立一个数据库,数据库编码设为UTF-8。此时,如果直接在命令行窗口使用insert语句插入中文,就遇到类似 ERROR 1406 (22001): Data too long for column 'name' at row 1 错误。乍一看,是字段长度引起的问题,但是实际是字符编码的问题。可是尝试以下解决方法:
1、在Linux中,使用终端方式登陆MySQL服务器,运行以下命令:
set names utf8;
该命令将终端的字符编码设为了UTF-8。此后再插入数据库中的内容都会按照UTF-8的编码来处理。
注意:在Linux中,终端方式中直接插入中文内容,可能并不会出现1406错误,但是这时插入的数据
是按照系统的默认编码进行处理。因此对编码为UTF-8的数据库,在显示数据的地方可能会出现乱码。

2、在Windows下,命令行窗口不支持UTF-8编码,所以使用“set names utf8;”不会达到转化中文的
效果。但是这个问题还是可以解决的:
(1)使用默认编码建立数据库。这种情况下就可以直接输入中文了,但是相应的问题,就是会
失去UTF-8编码的灵活性。特别是不利于软件的国际化。
(2)放弃命令行窗口登录MySQL,使用图形化客户端。客户端工具可以MySQL的官方网站上找到。”

B. Mysql配置文件:
“在my.ini里找到sql- mode='STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'把其中 的STRICT_TRANS_TABLES,去掉,或者把sql- mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION注释掉,然 后重启mysql就ok了”
取消 评论
如果你从mysql客户端直接向数据库中插入中文成功的话,那就不是数据库编码的问题,而是你你做的页面文件的编码格式和数据库不一致,比如你用php开发一个网站,php编码是utf8的,但是数据库编码却是gbk的,这时使用php向数据库中插入中文就会出现乱码,你可以到网上搜索一下编码转换的一些方法。
使用浏览器浏览一下页面,看一下页面编码和数据库编码是否一致。
取消 评论
肯定是数据库编码的问题
取消 评论
建数据库的时候选择正确的字符集,还有,程序里最好做必要的转码
取消 评论
报什么错误?是不是字符集不对
取消 评论
因为utf8就是容易出现乱码。
取消 评论
写入的数据也要是UTF-8
取消 评论
怎么个乱码法? 在那乱码
取消 评论
加载全部9个答案 加载中...
ZOL问答 > Mysql数据库不能插入中文为什么儿啊?

举报

感谢您为社区的和谐贡献力量请选择举报类型

举报成功

经过核实后将会做出处理
感谢您为社区和谐做出贡献

提示

确定要取消此次报名,退出该活动?