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

最新文章

  1. 关于ubuntu下sublime text 3 的安装和中文配置问题
  2. sessionid如何产生?由谁产生?保存在哪里?
  3. Javascript函数式编程要掌握的知识点讲解
  4. WinForm 多窗体
  5. 自定义tld标签,页面使用
  6. Python fopen,open,和popen的区别
  7. php连接MongoDB
  8. iOS之Xcode8 Auto Layout新特性
  9. jdbc_连接数据库
  10. 运行时改变控件的大小(点击后立刻ReleaseCapture,然后计算位移,最后发消息改变位置)——最有趣的是TPanel其实也有窗口标题,因此可发HTCAPTION消息
  11. Unix C++(boost) 线程同步和线程组
  12. Linux 常用性能工具简介
  13. 【ASP.NET Core】依赖注入高级玩法——如何注入多个服务实现类
  14. ArcGIS AddIn 批量设置栅格图层背景色为透明
  15. 自学Python4.5-装饰器举例
  16. android:onClick都做了什么
  17. Ubuntu16.10下使用VSCode开发.netcore
  18. Token的生成和检验
  19. XAML属性赋值转换之谜(WPF XAML语法解密)
  20. 《Linux内核分析》 第四节 扒开系统调用的三层皮(上)

热门文章

  1. AngularJs 第一个自定义指令编写
  2. 报表导出excel方式介绍
  3. apache ftp server的外网访问问题
  4. 使用docker安装使用gitlab
  5. 分享:Windows2008重启后提示系统恢复选项的解决办法
  6. JAVA使用POI如何导出百万级别数据
  7. ELT探索之旅2 kettle配置
  8. python2.7下同步华为云照片的爬虫程序实现
  9. 铁乐学python_Day42_线程池
  10. Mongodb极简实践