博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql数据库使用insert语句插入中文数据报错
阅读量:6986 次
发布时间:2019-06-27

本文共 849 字,大约阅读时间需要 2 分钟。

在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%';

来源:

转载地址:http://setpl.baihongyu.com/

你可能感兴趣的文章
使用ulimit设置文件最大打开数
查看>>
XmlHttpRequest 对象详解
查看>>
浅析Banner设计
查看>>
SQL Server扩展事件(Extended Events)-- 将现有 SQL 跟踪脚本转换为扩展事件会话
查看>>
传说中的裸奔节--认识及体验CSS
查看>>
二十年后的回眸(2)——顺风顺水的前三年
查看>>
烂泥:为KVM虚拟机添加网卡
查看>>
数据驱动安全架构升级---“花瓶”模型迎来V5.0(二)
查看>>
Sql Server 常用日期格式
查看>>
让“云”无处不在-Citrix Xenserver之一 环境搭建
查看>>
CentOS 5.5下LVM的分区管理
查看>>
Vsftp与PAM虚拟用户
查看>>
GoogleAppEngine是什么?
查看>>
利用 UML 进行实体关系建模
查看>>
WCF中的Stream操作
查看>>
.NET实现之(WebService数据提供程序)
查看>>
Spread for Windows Forms快速入门(8)---单元格中用户动作触发的事件
查看>>
XXX管理平台系统——概要
查看>>
常用思科设备图标(JPG+矢量图)
查看>>
倒排列表求交集算法 包括baeza yates的交集算法
查看>>