今天系统升级,开发、测试说本地环境、测试环境都没有问题,都用ssh client升的,演示环境报错了Data too long for column。

仔细检查了下,表字符集都是utf-8,目测长度肯定没超过。仔细查了下,问题出在character_set_client上。如下所示:

mysql> show create table t_char;
+--------+-----------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+--------+-----------------------------------------------------------------------------------------------------------------------------+
| t_char | CREATE TABLE `t_char` (
`id` int(11) DEFAULT NULL,
`name` varchar(32) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+--------+-----------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> show variables like '%char%';
+--------------------------+------------------------------------------------------------------------------+
| Variable_name | Value |
+--------------------------+------------------------------------------------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/Percona-Server-5.6.30-rel76.3-Linux.x86_64.ssl101/share/charsets/ |
+--------------------------+------------------------------------------------------------------------------+
8 rows in set (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试');
Query OK, 1 row affected (0.01 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测试');
Query OK, 1 row affected (0.00 sec)

mysql> commit;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试');--32个字符,肯定没有问题。
Query OK, 1 row affected (0.01 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试');--34,必然的。
ERROR 1406 (22001): Data too long for column 'name' at row 1

mysql> set character_set_client=gbk;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测试');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试1');
Query OK, 1 row affected (0.01 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试');
Query OK, 1 row affected (0.01 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试');--20个字符,
Query OK, 1 row affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测试'); --22个字符
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测1'); --20个中文,一个数字
Query OK, 1 row affected, 1 warning (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测11'); --20个中文,两个数字
ERROR 1406 (22001): Data too long for column 'name' at row 1

mysql> set character_set_client=latin1;
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id: 3188579
Current database: test

Query OK, 0 rows affected (0.00 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测试测试测试测试测试测1');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t_char values(1,'测试测试测试测试测试');--10个字符
Query OK, 1 row affected (0.01 sec)

mysql> insert into t_char values(1,'测试测试测试测试测试测'); --11个字符
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t_char values(1,'aaaaaaaaaa');
Query OK, 1 row affected (0.01 sec)

==========================

再看表时gbk字符的情况:

mysql> create table test_g(id int,name varchar(32)) charset=gbk;

mysql> set character_set_client=gbk;
Query OK, 0 rows affected (0.06 sec)

mysql> insert into test_g values(1,'测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试');--30个字符
ERROR 1406 (22001): Data too long for column 'name' at row 1

mysql> insert into test_g values(1,'测试测试测试测试测试测试测试测试测试测试测试测试测试');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into test_g values(1,'测试测试测试测试测试测试测试测试测');
ERROR 1366 (HY000): Incorrect string value: '\x8B' for column 'name' at row 1

mysql> insert into test_g values(1,'测试测试测试测试');
Query OK, 1 row affected (0.30 sec)

mysql> select * from test_g;
+------+--------------------------------------+
| id | name |
+------+--------------------------------------+
| 1 | 娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯 |
+------+--------------------------------------+
1 row in set (0.51 sec)

mysql> insert into test_g values(1,'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa');
Query OK, 1 row affected (0.01 sec)

mysql> insert into test_g values(1,'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> set character_set_client=utf8;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into test_g values(1,'测试测试测试测试');
Query OK, 1 row affected (0.06 sec)

mysql> select * from test_g;
+------+--------------------------------------+
| id | name |
+------+--------------------------------------+
| 1 | 娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯 |
| 1 | aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa |
| 1 | 测试测试测试测试 |
+------+--------------------------------------+
3 rows in set (0.00 sec)

mysql> insert into test_g values(1,'测试测试测试测试测试测试测试测试测');
Query OK, 1 row affected (0.39 sec)

mysql> select * from g;
ERROR 1146 (42S02): Table 'test.g' doesn't exist
mysql> select * from test_g;
+------+-----------------------------------------------------+
| id | name |
+------+-----------------------------------------------------+
| 1 | 娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯 |
| 1 | aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa |
| 1 | 测试测试测试测试 |
| 1 | 测试测试测试测试测试测试测试测试测 |
+------+-----------------------------------------------------+
4 rows in set (0.09 sec)

mysql> insert into test_g values(1,'测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试');  --32个字符
Query OK, 1 row affected (0.00 sec)

mysql> insert into test_g values(1,'测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测'); --33个字符
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> select * from test_g;
+------+--------------------------------------------------------------------------------------------------+
| id | name |
+------+--------------------------------------------------------------------------------------------------+
| 1 | 娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯 |
| 1 | aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa |
| 1 | 测试测试测试测试 |
| 1 | 测试测试测试测试测试测试测试测试测 |
| 1 | 测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试 |
+------+--------------------------------------------------------------------------------------------------+
5 rows in set (0.00 sec)

实际结果比较怪异,不管建表用的是gbk还是utf8,insert时,Mysql对于客户端连接的字符集好像只有utf-8是正常识别的,gbk好像总是有问题。数据库gbk/客户端gbk也进行了编码转化导致乱码,好怪异的行为。

mysql乱码以及Data too long for column全解(最完整实用版)的更多相关文章

  1. mySql | Error: ER_DATA_TOO_LONG: Data too long for column 'base_info' at row 1

    问题描述:执行insert语句报以下错误 原因:数据库表,该字段在设计的时候长度过小,新插入的数据过长,会提示以上错误! 解决办法:修改表中该字段的长度限定.

  2. MySQL插入中文时出现ERROR 1406 (22001): Data too long for column 'name' at row 1 (转)

    使用命令行方式登陆到MySQL服务器, 建立一个数据库,数据库编码设为UTF-8.此时,如果直接在命令行窗口使用insert语句插入中文,就遇到类似 ERROR 1406 (22001): Data ...

  3. sql点滴37—mysql中的错误Data too long for column '' at row 1

    原文:sql点滴37-mysql中的错误Data too long for column '' at row 1   1.MYSQL服务 我的电脑——(右键)管理——服务与应用程序——服务——MYSQ ...

  4. Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'content' a

    1.错误描述 org.hibernate.exception.DataException: could not execute statement at org.hibernate.exception ...

  5. mysql修改字段长度及pymysql.err.DataError: (1406, "Data too long for column 'name' at row 1")错误

    文章链接:修改字段:https://blog.csdn.net/xiejunna/article/details/78580682 错误分析:https://blog.csdn.net/qq_4214 ...

  6. Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'img' at row 1故障

    Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'img' at ro ...

  7. 数据库报错com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'ua' at row 1

    记一次报错记录,成长路上的点滴 明明使用浏览器或者微信开发工具调试接口没有问题,但是在真机测试时候就出问题了.(((¬_¬)) 500服务器内部错误,要死的节奏啊 登陆tomcat服务器 使用命令ta ...

  8. com.mysql.jdbc.MysqlDataTruncation:Data Truncation:Data too long for column '字段name' at row 1

    1.问题描述: 在mysql插入数据的时候报错:Cause: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long fo ...

  9. Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Incorrect datetime value: '' for column 'createtime' at row 1...

    之前项目一直好好的,之后电脑重装系统,数据库重新安装了一个5.6版本的,项目jar包丢失了,之后就又重新找了一些jar包倒入,结果运行报错: Caused by: com.mysql.jdbc.Mys ...

随机推荐

  1. 分享7款非常实用的jQuery/CSS3插件演示和源码

    上次我们分享了15款效果很酷的最新jQuery/CSS3特效,非常不错,今天要分享7个非常实用的jQuery/CSS3插件演示和源码,一起来看看. 1.jQuery ajax点击地图显示商家网点分布 ...

  2. java&postgresql时区总结

    介绍这篇文章之前,首先回答一个问题,以前都没有时区的概念,程序也写的好好的,为什么要计算时区哪?举个例子,比如有一个订单的时间是:2015-07-04 11:28:19,那么咋一看没什么问题,可是如果 ...

  3. maven快照版本和发布版本

    在使用maven过程中,我们在开发阶段经常性的会有很多公共库处于不稳定状态,随时需要修改并发布,可能一天就要发布一次,遇到bug时,甚至一天要发布N次.我们知道,maven的依赖管理是基于版本管理的, ...

  4. BZOJ 1251 序列终结者(Splay)

    题目大意 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术 ...

  5. 多个Storyboard的使用

    创建一个Storyboard工程 storyboard是在ios5中引入的新控件,能够更加清晰.简单的整合多个ViewController的关系,下面主要介绍一下怎么初建一个storyboard的工程 ...

  6. Qt 判断文件是否存在

    包含头文件:<QFileInfo> 代码: QFileInfo file("文件路径"); if(file.exists()==false){文件不存在:}

  7. HIVE: UDF应用实例

    数据文件内容 TEST DATA HERE Good to Go 我们准备写一个函数,把所有字符变为小写. 1.开发UDF package MyTestPackage; import org.apac ...

  8. Qt5 从头学(1)-- 环境

    对我来说MFC太过麻烦了,同样是桌面开发工具,Qt就完全不一样了.Qt使用C++语言可以轻松实现"一次编写,到处编译"的跨平台性能,并且可以做出很多炫酷的界面效果.目前支持几乎所有 ...

  9. Lua基础

    局部定义与代码块: 使用local声明一个局部变量或局部函数,局部对象只在被声明的那个代码块中有效. 代码块:一个控制结构.一个函数体.一个chunk(一个文件或文本串)(Lua把chunk当做函数处 ...

  10. gulp-uglify《JS压缩》----gulp系列(四)

    本节实现JS压缩,在实现压缩前,先配置JS任务,设置源目录和输出目录. 在系列(三)代码的基础上,再进行扩展. 1.找到gulp->config.js,对JS进行源目录(src->img) ...