mysql数据库使用insert语句插入中文数据报错
2019-03-27 17:01
211 查看
在mysql的命令行模式中,通过insert语句插入中文数据的时候报错,类似于下面这样:
Incorrect string value: '\xE7\x8F' for column 'name' at row 1
造成这个错误通常是由于创建数据表的时候使用了不正确的编码格式,可以使用如下命令查看操作的目标数据表的编码格式。
SHOW CREATE TABLE 表名;
通过结果就可以看到目标表的目标字段对应的编码格式,我们只需要把该列的编码格式转化为
utf8即可。
ALTER TABLE 表名 MODIFY 列名 数据类型 CHARACTER SET utf8 非空约束 例如:ALTER TABLE student MODIFY name VARCHAR(20) CHARACTER SET utf8 NOT NULL
当然这只是一个临时的解决办法,更近一步的解决办法是修改数据表的编码,防止以后在使用命令添加数据列的时候,使用的仍是数据表的编码。
ALTER TABLE 表名 DEFAULT CHARSET utf8;
然后这还不是最终的解决办法,我们还可以通过修改数据库的编码方式来影响新创建的数据表的编码方式,进而影响数据列的编码方式。
ALTER DATABASE 数据库名 DEFAULT CHARACTER SET utf8;
但是这需要我们每次在创建数据库的时候都必须指定编码方式,要想一劳永逸,我们可以直接去修改mysql的配置文件,使用如下命令:
vim /etc/mysql/mysql.cnf.d/mysqld.cnf
添加如下配置
[mysqld] character-set-server=utf8
保存之后重新启动mysql服务即可,命令如下(以Ubuntu16.04为例):
systemctl restart mysql.service
注意在设置编码格式的时候,使用如下命令查看支持的编码格式:
SHOW VARIABLES LIKE 'char%';
相关文章推荐
- 使用hibernate往mysql数据库插入数据中文乱码问题
- Qt SQL学习笔记三:qt使用INSERT语句将数据插入表中
- SQL语言使用insert语句向数据库表格中插入或添加新的数据行
- Android笔记--解决使用php文件插入数据到mysql数据库的表中中文变问号的问题
- Linux下安装的mysql数据库插入中文乱码或sql查询语句条件中有中文查不到数据
- 使用mybatis的insert语句插入数据的时候,获取插入数据的主键id
- MYSQL数据库(十)- 数据表的插入(insert)、删(delete)、改(update)、查(select)、group by 分组、having语句设置分组条件,order by查询结果排序,
- 使用insert 语句插入另一个表和几个传入数据时,写法:
- python中使用pymysql往mysql数据库中插入(insert)数据
- SQL语句(增、删、改、查)一、增:有4种方法1.使用insert插入单行数据:语法:insert
- (八大方法、逐层深入,有你一定没见过的)使用INSERT语句向表中插入数据
- (八大方法、逐层深入,有你一定没见过的)使用INSERT语句向表中插入数据
- (八大方法、逐层深入,有你一定没见过的)使用INSERT语句向表中插入数据
- 【SQL Server学习笔记】5:使用INSERT语句插入数据
- MYSQL使用存储过程插入中文数据的疑似bug(UTF8)
- T-SQL 语句插入中文数据时数据库显示全是问号“???”的解决方法(数据库编码规则)
- Python MySQLdb 使用utf-8 编码插入中文数据
- Python MySQLdb 使用utf-8 编码插入中文数据
- 将表数据生成Insert脚本 比较好用的生成插入语句的SQL脚本
- MSSQL 中使用modify()方法,此方法使用XML DML语句在XML 数据中插入,更新或删除节点