mysql数据库使用insert语句插入中文数据报错
程序员文章站
2023-11-11 18:15:10
在mysql的命令行模式中,通过insert语句插入中文数据的时候报错,类似于下面这样: 造成这个错误通常是由于创建数据表的时候使用了不正确的编码格式,可以使用如下命令查看操作的目标数据表的编码格式。 通过结果就可以看到目标表的目标字段对应的编码格式,我们只需要把该列的编码格式转化为 即可。 当然这 ......
在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%';
推荐阅读
-
mysql数据库使用insert语句插入中文数据报错
-
Mysql查询语句使用select.. for update导致的数据库死锁分析
-
Mysql数据库中的 Order by 语句的特殊之处(select 中的项目不必出现在order by中)---不建议使用!
-
asp中用insert into语句向数据库插入记录(添加信息)的方法
-
数据库~dotnetcore连接Mysql插入中文失败
-
使用SQL语句修改Mysql数据库字符集的方法
-
SQLSever语句(增、删、改、查)一、增:有4种方法1.使用insert插入单行数据
-
PHP使用PDO创建MySQL数据库、表及插入多条数据操作示例
-
Mysql使用insert插入多条记录 批量新增数据
-
数据库MySql python读取插入数据,insert对那些类型加单引号,表单自己参考自己(外键),空值和NULL