• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

中文字符 Mysql Data too long for column ‘name’ at row 一

mysql 搞代码 7年前 (2018-06-05) 122次浏览 已收录 0个评论

中文字符 mysql Data too long for column ‘name’ at row 1
INSERT INTO Shenzhen ( ItemId , Title , City , PostCode , X , Y , en_title ) VALUES ( 1720 , ‘深圳新闻-Shenzhen Post’ , ‘深圳市’ , ” , 114311218 , 22598236 , ‘2’ )

刚刚在做一个插入操作的时候提示
1046 – Data too long for column ‘Title’ at row 1

解决办法如下

1,mysql的编码设置为 utf8 格式,可以从开始菜单那图形化配置,或者直接进入安装目录配置my.ini

2,在java连接数据库时这样写:

String url =”jdbc:mysql://localhost/sales?user=root&password=riskfitfeng&useUnicode=true&characterEncoding=utf-8″;

3,数据库的编码为 utf8

4,数据库表编码为 utf8

5,数据库字段编码为 utf8
——————————————————————–
最近,在用mysql做一个测试用例的时候,出现乱码。

现象:无论是从MySQL Query Browser还是Java程序插入数据库,只要插入中文字符, 就会报错“Data too long for column ‘XXXXX’ ”。这里,显然不是字段长度设置太短的问题。

在网上查资料,大多介绍不外乎下面集中解决方法:

1.修改Server端编码。修改character_set_xxx

2.在JDBC-URL连接后面加上&useUnicode=true&characterEncoding=UTF8

3.修改my.ini文件
去掉sql-mode = “STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION”中的STRICT_TRANS_TABLES

真是病急乱投医,所以该试的方法都试了,问题依然无法解决。

被这个问题折磨的实在不行了,最后准备卸载重装一次。再不行,就去别人的机器上试下。在备份表的SQL语句时,发现

DROP TABLE IF EXISTS `test`.`test1`;
CREATE TABLE `test`.`test1` (
column_name column_type [charset latin7]
) ENGINE=InnoDB DEFAULT CHARSET=latin7;
最后面,竟有这么一句:
DEFAULT CHARSET=latin7。

直接晕倒,明明已经在MySQL Query Browser中将表的编码设置成UTF8了,怎么是latin7。改成UTF8,问题解决。
看来,有时候不能太相信可视化的编辑器,还是直接的SQL最直接。

还有,就是查看下表的字段也有column charset选项,看是否设置正确了。

综上所述,出现乱码后,一定检查数据库服务器、库、表、字段的编码设置是否支持中文。

经过试验,只要上述都设置为UTF8,即使,URL后面不添加useUnicode=true&characterEncoding=UTF8就不会出现乱码。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:中文字符 Mysql Data too long for column ‘name’ at row 一

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址