问题在哪?
“只有客户发展了,才有我们的生存与发展!”这是成都创新互联的服务宗旨!把网站当作互联网产品,产品思维更注重全局思维、需求分析和迭代思维,在网站建设中就是为了建设一个不仅审美在线,而且实用性极高的网站。创新互联对网站建设、网站设计、网站制作、网站开发、网页设计、网站优化、网络推广、探索永无止境。
中文乱码问题,有几个需要注意的地方:
1、确保你数据库的字符集是支持中文的;
2、如果数据库保存的是中文但是显示的时候是乱码则需对客户端字符集进行设置,如set names gbk;
3、如果程序中导入或导出的时候产生的乱码需要确保客户端字符集正确,并保证修改的命令和导入导出命令在同一个会话中。
1、MySQL默认的字符集是UTF8;
2、对于字符集的支持细化到四个层次:服务器(server),数据库(database),数据表(table)和连接(connection)。
3、具体的字符集可以通过修改配置文件(my.cnf)进行调整。
理论上说起来,设置为 utf8 也并非一个完全合适、100% 没毛病的值,即便你将 MySQL 的字符集设置为 utf8 ,也有可能出现乱码!
通过以下命令,你可以查看 MySQL 所支持的所有『字符集』编码:
在显示的 Charset ,你会看见熟悉的 utf8 。
如果你再仔细看一下这一行,你会发现这一行的 Maxlen 列中的值居然是 3 !?
这是 MySQL 中的 utf8 并非我们现在常说的 『真·UTF8』 。它『 最多 』只用 3 个字节存储一个字符,而有些中日韩生僻字small(包括 emoji 表情)/small的 Unicode 编码是需要 4 个字节宽度才能存储的,这就会导致一些乱码的隐患。
MySQL 解决这个问题的方案是绕过 utf8 提出一种新的字符集来实现 『 真·UTF8 』 功能: utf8mb4 。
实际上,为了统一称呼,MySQL 在提出 utf8mb4 字符集之后,就将 utf8 改为 utf8mb3 的别名,因此,你设置字符集为 utf8 本质上就是设置成了 utf8mb3 。
在更高版本(8.x)的 mysql 中,MySQL 直接将 utf8 改为了 utfmb4 的别名。
错误原因:1.数据超长或类型不匹配; 2.数据库记录重复
解决方案:如果输入内容超多,应该把你的内容用 addslashes 处理。
如果输入值超过类型最大限度,请修改好自动类型。比如类型32位为int,输入内容超出2147483647