mysql为什么向表中插入中文会报错?编码都设置了UTF8了

mysql为什么向表中插入中文会报错?编码都设置了UTF8了,第1张

你的MYSQL语句用错了。 如果你的mysql数据库的字符集整理是用gbk或gb2312的话,你应该加的是mysql_query("set names gbk"),<meta http-equiv="content-type" content="text/htmlcharset=gbk"/> 如果字符集整理时用utf8,那么你就应该在存取、读取数据库前增加mysql_query("set names utf8"),然后页面头部<meta http-equiv="content-type" content="text/htmlcharset=utf8"/>

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了”

Incorrect string value: '/xE7/xA8/x8B/xE5/xBA/x8F...' for column 'course' at row 1

出现这个错误的原因是,数据库的编码格式为latin1 而我要将utf8的中文插入到数据库中。

一开始修改 修改数据库的编码

alter table score default character set utf8

但是插入中文依然出现错误。

然后通过查看数据表编码

show create table score

发现如下所示

注意 course 的编码仍然为 latin1 ,虽然此时表的编码已经是 utf8 , 但是不知道为什么 列的编码没有更改过来

下面就是更改列的编码即可

alter table score change score score varchar(50) character utf8

修改成功之后

结果是列的编码已经修改成功


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9727051.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存