本文主要是介绍1406 - Data too long for column ‘deintro‘ at row 1报错原因以及解决办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
今天用MySql数据库打算插入几个数据,大约有几千个汉字左右,插入的时候出现了这个错误。
1406 - Data too long for column ‘deintro’ at row 1
问题原因:
开始设置的数据类型为varchar,要输入的数据较多
插入的数据比数据类型大,会被截断时,就会报错,无法插入。
解决办法:
后来我把varchar数据类型换成了mediumtext。
这样就不会报错了。
新的问题:
问题一
mediumtext类型长度无法更改,数据表中长度为0,改成别的值保存仍为0。
答:这个类型是在另外开辟了一个存储空间保存的,表中是存了一个指针指向这个外部存储空间的问题。存储的长度也是固定的。
问题二
虽然可以插入文字了,但是插入的汉字有字数限制,仅仅可存储700多个字符。
答:这个还没解决
问题三
数据我存进去了,显示的也是汉字,但是我把数据库表格关闭重新打开后,数据统一变成了(BLOB)
答:后来我查了一下。text字段如果使用utf8_bin编码,数据库会显示blob,并且会乱码。我看了一下自己的也确实用的UTF8-bin编码。
解决办法:把utf8-bin改成utf8_general_ci就可以了
另外在这里科普一下utf8_unicode_ci、utf8_general_ci和utf8_bin这几个的区别:
utf8__bin是用二进制存储并比较,区别大小写,存储二进制内容时使用
utf8_general_ci:校对速度快,但准确度稍差,使用中英文时使用
utf8_unicode_ci:准确度高,但校对速度稍慢,使用德法俄等外语时使用
这样就一目了然了。
这篇关于1406 - Data too long for column ‘deintro‘ at row 1报错原因以及解决办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!