mysql为什么不能插入数据_mysql为啥不能插入数据

mysql为何不能插入数据?

安装AppServ后首次使用mysql,没有图形界面,在“MySql Command Line Client”的操作如下:

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

mysql> create database cars;

Query OK, 1 row affected (0.00 sec)

mysql> use cars;

Database changed

mysql> create table cars(id int,xm char(8),h char(8),vin char(20));

Query OK, 0 rows affected (0.06 sec)

mysql> insert into cars(id,xm,h,vin) values(1,'廉东方','豫A5F568','LDC666L2980790000');

Query OK, 1 row affected, 1 warning (0.02 sec)

mysql> select * from cars;

+------+------+----------+-------------------+

| id | xm | h | vin |

+------+------+----------+-------------------+

| 1 | | 豫A5F568 | LDC666L2980790000 |

+------+------+----------+-------------------+

1 rows in set (0.02 sec)

mysql> select xm from cars;

+------+

| xm |

+------+

| |

+------+

1 rows in set (0.00 sec)

mysql> update cars set xm='廉' where id=1;

Query OK, 0 rows affected, 1 warning (0.01 sec)

Rows matched: 1 Changed: 0 Warnings: 0

为何不能设置xm字段的值?为何无法更新?谢谢啦~~~

------解决方案--------------------

你 #1 的内容是我在#3回复后才看到的,不然一开始就解释了

\xC1\xAE\xB6\xAB\xB7\xBD 是 廉东方 的gbk 内码

而他却报错了,这说明你的数据库的默认字符集不是 latin1 的,也不是 gbk 的

那么对中文报错就只能是 utf8 的了(极少有人用 ucs-2 的,就算是也没关系)

对 utf8 字段插入 gbk 字符当然就要报错了

所以要 set names gbk 通知 mysql 现在用的是 gbk 字符

那么“豫”为什么没有报错呢?

这就要看 utf-8 是如何编码的了:

U+007F 0xxxxxxx

U+07FF 110xxxxx 10xxxxxx

U+FFFF 1110xxxx 10xxxxxx 10xxxxxx

U+1FFFFF 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx

U+3FFFFFF 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx

U+7FFFFFFF 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx

豫 的gbk二进制内码为 11010100 10100101

正好符合 U+07FF 编码规则,所以他就不会报错

相关文章

相关视频

网友评论

文明上网理性发言,请遵守 新闻评论服务协议我要评论

47d507a036d4dd65488c445c0974b649.png

立即提交

专题推荐064df72cb40df78e80e61b7041ee044f.png独孤九贱-php全栈开发教程

全栈 100W+

主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门

7dafe36c040e31d783922649aefe0be1.png玉女心经-web前端开发教程

入门 50W+

主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门

04246fdfe8958426b043c89ded0857f1.png天龙八部-实战开发教程

实战 80W+

主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值