问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

Mysql数据库不能插入中文怎么回事儿啊?

发布网友 发布时间:2022-04-23 16:19

我来回答

4个回答

懂视网 时间:2022-04-07 23:24

故障码:

mysql> insert into t1(name,sex,age,address) values('张三','男',11,'沙河');
ERROR 1366 (HY000): Incorrect string value: 'xD5xC5xC8xFD' for column 'name'
 at row 1


该故障是由于中文编码不一致导致的数据插入失败所致。


        一般mysql数据库在插入中文信息时出错的情况无外乎就是中文编码不一致所致。而目前支持中文的编码格式基本上有utf-8,gbk,gb2312三种,而数据库,jsp页面,控制台,Java代码等等的地方要尽可能的编码一致,否则可能会带来不必要的麻烦。


通过查找,我发现我的数据库编码格式是:utf-8,如下所示:

[mysql]

default-character-set=utf8


该信息在mysql的安装目录下的my.ini文件中,以我的为例,就是:C:Program FilesMySQLMySQL Server 5.5下的my.ini。


而我们的控制台的编码格式是:gbk,如下图所示:
技术分享


控制台的打开方式是【开始】->【运行】,在【运行】窗口中输入cmd,点击回车键即可。


        由于控制台和mysql的中文编码格式不一致,这导致中文数据无法插入成功,解决办法就是将其编码格式进行统一,由于控制台的编码格式不能进行设置,所以我们只有更改数据库的编码格式了,此时我们将数据库的编码格式也改成gbk。


即,将my.ini文件中的utf-8改成gbk,代码如下:

[mysql]

default-character-set=gbk

此时重启mysql服务器,然后再插入中文数据,运行结果如下所示:

mysql> insert into t1(name,sex,age,address) values('张三','男',11,'沙河');
Query OK, 1 row affected (0.05 sec)







cmd控制台插入mysql数据库中文信息时,插入失败的解决办法

标签:mysql   控制台   

热心网友 时间:2022-04-07 20:32

Mysql数据库不能插入中文,一插入就报错,是代码输入错误造成的,解决方法如下:

1、首先使用insert语句,把数据插入到数据库表里。

2、运行后,发现插入语句报错了。点击语句,查看详情,提示说插入的中文语句是不正确的字符串内容。

3、这时右键点击插入数据的表,然后点击表设计。

4、打开表设计界面后,点击上方的Option选项。

5、默认新建的表字符集用的是latin1字符集。要插入中文内容,需要将其改成ubf8字符集。

6、除此之外,需要保存中文内容的字段,也需要将其改成utf8字符集。

7、修改好,保存后,再次运行插入sql语句,可以看到成功插入中文数据了。

热心网友 时间:2022-04-07 21:50

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

热心网友 时间:2022-04-07 23:24

报什么错误?是不是字符集不对
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
可以教会聋哑人说话吗 我是一位聋哑的男孩,想学说话,不会说话,怎么办 聋哑人可以说话吗 雾炮机工作原理是什么? 等离子火焰清洗机 vigi是什么意? 加尔文和马丁路德的区别是什么?区别很大吗? 玄参目分类介绍 如何根据植物形态判断科属 植物学小白怎么鉴定植物标本? 怎样用电饭煲做煲仔饭?详细步骤!谢谢~~ mysql数据库插入数据库出现中文乱码问题 语音聊天时为什么会有回音 mysql出现乱码问题如何解决? mysql5写入中文乱码 创维冰箱质量怎么样? 自己说话有回音是怎么回事 创维冰箱的创维白电发展历程 为什么我说话对面会有回音 用mysql数据库在前台页面插入中文信息出现乱码怎么解决 请问:创维冰箱质量怎么样? mysql 数据库乱码问题,页面,数据库都是UTF-8 的字符集,为什么INSERT IN... 创维82Q80怎么查询激活时间 创维冰箱条形码是多少位 日食先从哪边开始(东或西) 怎样看创维液晶电视机的出厂日期 中国21世界的下一次日全食是哪一年? 创维冰箱日期谁能看懂? 2019年日全食哪天啊? 图里怎么看冰箱的生产日期? mysql中文乱码 为什么我用语音聊天有回音? java项目向mysql中插入中文出现乱码!求解!!! MYSQL5输入中文产生乱码 手机讲话有回音是什么原因? 手机讲话有回音,经常这样 JSP添加中文数据到MySQL5中,为何出现乱码。怎么解决。谢谢 黑眼圈 是什么? 黑眼圈什么原因? 黑眼圈是怎么回事啊? 黑眼圈到底是什么原因 黑眼圈是怎么回事呢? 我要吐槽作文关于父母 吐槽爸妈作文 现在的小学生脑洞太大了,你听过小朋友怎么吐槽家长? 吐槽父母的幽默句子 白岩松:教育最值得吐槽的是家长,家长是不是承担了太多? 虽然为人儿女,但是有时候还是想吐槽一下父母 PPT如何创建列表型smartart图形,SmartArt图形怎么创建--文稿 孩子吐槽父母不能给他好的生活,作为父母,应该作何回应呢?