插入失败

java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for column 'name' at row 1
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2620)
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1662)
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1581)

1、linux 处理步骤:修改my.cnf vi /etc/my.cnf

[mysqld]

character-set-server=utf8mb4

[mysql]

default-character-set=utf8mb4

修改后重启Mysql

2. 以root身份登录Mysql

查看当前字符集 show variables like ‘character_set_%’

show variables like ‘collation_%’;

修改环境变量,将一下都修改成utf8mb4

1、set character_set_client = utf8mb4;

2、set character_set_connection = utf8mb4;

3、set character_set_database = utf8mb4;

4、set character_set_results = utf8mb4;

5、set character_set_server = utf8mb4;

3. 将已经建好的表或字段转换成utf8mb4

修改表:alter table TABLE_NAME convert to character set utf8mb4 collate utf8mb4_bin; (将TABLE_NAME替换成你的表名)

修改字段:alter table table_name modify column name varchar(64) character set utf8mb4;

4. 知识补充 MYSQL 字符集问题

  • MySQL的字符集支持(Character Set Support)有两个方面:字符集(Character set)和排序方式(Collation)。
  • 对于字符集的支持细化到四个层次: 服务器(server),数据库(database),数据表(table)和连接(connection)。
  1. MySQL默认字符集

MySQL对于字符集的指定可以细化到一个数据库,一张表,一列,应该用什么字符集。
但是,传统的程序在创建数据库和数据表时并没有使用那么复杂的配置,它们用的是默认的配置,那么,默认的配置从何而来呢?

(1)编译MySQL 时,指定了一个默认的字符集,这个字符集是 latin1;

(2)安装MySQL 时,可以在配置文件 (my.ini) 中指定一个默认的的字符集,如果没指定,这个值继承自编译时指定的;

(3)启动mysqld 时,可以在命令行参数中指定一个默认的的字符集,如果没指定,这个值继承自配置文件中的配置,此时 character_set_server 被设定为这个默认的字符集;

(4)当创建一个新的数据库时,除非明确指定,这个数据库的字符集被缺省设定为character_set_server

(5)当选定了一个数据库时,character_set_database 被设定为这个数据库默认的字符集;

(6)在这个数据库里创建一张表时,表默认的字符集被设定为 character_set_database,也就是这个数据库默认的字符集;

(7)当在表内设置一栏时,除非明确指定,否则此栏缺省的字符集就是表默认的字符集;

简单的总结一下

如果什么地方都不修改,那么所有的数据库的所有表的所有栏位的都用latin1 存储,不过我们如果安装 MySQL,一般都会选择多语言支持,也就是说,安装程序会自动在配置文件中把default_character_set 设置为 UTF-8,这保证了缺省情况下,所有的数据库的所有表的所有栏位的都用 UTF-8 存储。

最新文章

  1. SQL Server中的GUID
  2. mysql-Federated存储方式,远程表,相当于sql server的linked server
  3. [改善Java代码]建议40:匿名类的构造函数很特殊
  4. IE JavaScript字符串转换成Date后出现NaN错误
  5. oracle归档日志管理
  6. FreeRTOS——队列管理
  7. 1.1 Python是一种什么样的语言
  8. echarts中饼图显示百分比
  9. Bitmap的秘密
  10. ccf--20150903--模板生成系统
  11. 学习笔记45—Linux压缩集
  12. Liferay
  13. JAVA虚拟机体系结构JAVA虚拟机的生命周期
  14. js阻止事件冒泡的两种方法
  15. C# 自定义控件入门
  16. 撩课-Web大前端每天5道面试题-Day8
  17. postgresql parallel join example
  18. iOS开发之-- 设置启动图片
  19. Java 排序(快排,归并)
  20. <转>jmeter JDBC Request之Query Type

热门文章

  1. iptables实现端口映射(本地和远程端口映射)
  2. 《精通CSS第3版》(5)漂亮的盒子
  3. (6)Flask项目之会员注册页面
  4. 记RDS数据库表数据误删恢复
  5. jqGrid设置单选
  6. 学习数据结构Day3
  7. [转帖]Linux教程(12)- linux输入输出重定向
  8. urlencode编码 — 为什么要编码
  9. Java基础笔试练习(七)
  10. Java开发笔记(一百零五)几种定时器线程池