MySQL的字符集配置

MySQL的字符集配置

创建database

bash 复制代码
create database dbtest1;
show databases;
bash 复制代码
use dbtest1;

创建表

bash 复制代码
create table employees(id int,name varchar(15));

插入数据

bash 复制代码
insert into employees values(1001,'杰瑞');

mysql8.0执行以上SQL可以正常执行,但在5.7版本则不能正常插入表。

为什么呢,通过show命令可以看出差异8.0默认utf8 ,而5.7默认字符集Latin1(瑞典的公司的MySQL)

bash 复制代码
show create table employees;

root@localhost : dbtest1 04:39:18>show create table employees;

±----------±-------------------------------------------------------------------------------------------------------------------------------+

| Table | Create Table |

±----------±-------------------------------------------------------------------------------------------------------------------------------+

| employees | CREATE TABLE employees (
id int(11) DEFAULT NULL,
name varchar(15) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=utf8 |

±----------±-------------------------------------------------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

mysql5.7查看创建表命令:可以看到是Latin1

查看字符集配置

bash 复制代码
show variables like 'character_%';

MySQL8的从查询数据库字符集变量:

MySQL5.7的从查询数据库字符集变量:

查看字符集的比较规则

bash 复制代码
show variables like 'collation_%';

MySQL8:

关于字符集的配置

主要是修改character_set_database和character_set_server属性,查询之后为utf8则表示修改完成。修改完后,已经创建好的库的字符集不会改变,需要手动改变或者重新创建数据库。

bash 复制代码
[mysql]
#字符集①
default-character-set=utf8
[mysqld]
#字符集②
character-set-server=utf8
#比较字符的比较规则
collation-server=utf8_general_ci 

修改之后的5.7:

修改字符集

bash 复制代码
#数据库
alter database dbtest1 charset utf8;
#表
alter table employees charset utf8;

总结

1、对于MySQL5.7默认latin1,需要修改字符集为utf8,否则处理汉字会有问题
2、而MySQL8默认utf8mb4,也可以改为utf8(utf8mb3),不需要修改。
3、utf8mb4表示4个字节表示一个字符。

相关推荐
qq_12498707531 分钟前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
游戏开发爱好者86 分钟前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
王码码203511 分钟前
Flutter for OpenHarmony 实战之基础组件:第三十一篇 Chip 系列组件 — 灵活的标签化交互
android·flutter·交互·harmonyos
黑码哥27 分钟前
ViewHolder设计模式深度剖析:iOS开发者掌握Android列表性能优化的实战指南
android·ios·性能优化·跨平台开发·viewholder
倒流时光三十年33 分钟前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
亓才孓39 分钟前
[JDBC]元数据
android
独行soc1 小时前
2026年渗透测试面试题总结-17(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
金融RPA机器人丨实在智能1 小时前
Android Studio开发App项目进入AI深水区:实在智能Agent引领无代码交互革命
android·人工智能·ai·android studio
科技块儿1 小时前
利用IP查询在智慧城市交通信号系统中的应用探索
android·tcp/ip·智慧城市