Incorrect string value: ‘\xE5\x8C\x97\xE4\xBA\xAC...‘ for column ‘name‘ at row 1 MySQL数据库提交中文数据报错

1. 问题描述

新建了一个MySQL数据库,但是在pycharm里自带的数据库工具新增中文数据submit时,提示下面的错误:

bookmanager> INSERT INTO bookmanager.publisher_publisher (name) VALUES ('北京大学出版社')
[2021-05-12 14:48:58] [HY000][1366] Incorrect string value: '\xE5\x8C\x97\xE4\xBA\xAC...' for column 'name' at row 1

但是,如果新增的数据是英文的,比如beijing press,就不会报错

bookmanager> INSERT INTO bookmanager.publisher_publisher (name) VALUES ('beijing press')
[2021-05-12 14:49:14] 1 row affected in 15 ms

2. 解决方法

在网上搜了一下,说是数据库的character set默认是latin1,需要修改成utf8,然后就用命令show create database bookmanager查询了一下,果然是latin1,然后使用命令alter database bookmanager default character set utf8修改成utf8,但是新增数据submit时,还是提示之前的错误,为什么还是不行呢?然后用命令show create table publisher_publisher查询了一下表的character set,发现表的类型没有修改,

CREATE TABLE `publisher_publisher` (
  `pid` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(32) NOT NULL,
  PRIMARY KEY (`pid`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1

于是用命令修改了一下,再提交中文数据就成功了。

bookmanager> INSERT INTO bookmanager.publisher_publisher (name) VALUES ('北京大学出版社')
[2021-05-12 15:06:24] 1 row affected in 3 ms
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值