IDE都是UTF-8,mysql编码也是UTF-8,仍然中文乱码

本文介绍了在MySQL数据库中遇到的中文乱码问题及其解决方法。通过调整表和字段的字符编码,成功解决了直接在数据库中执行INSERT语句时出现的乱码情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

*默认情况下,字段的字符编码与表的字符编码相同
也可以单独为字段指定其他字符编码*

今天往MySQL数据库中插入中文的时候,出现了乱码
这里写图片描述
页面编码、软件的编码都调试了,甚至如图:
这里写图片描述
换个思维:
直接在数据库可视化界面navicat for mysql中直接执行insert插入语句

insert into userinfo(user_name,user_password) values(‘张’,’zyy’)

仍然乱码~
查看了下
这里写图片描述
这里字符编码没有问题为什么直接在数据库这里插入还会乱码呢?
将表转储成sql语句看了下,发现如下:
这里写图片描述
多了 SET latin1的定义, 查了下资料,原来,Latin1是ISO-8859-1的别名,有些环境下写作Latin-1,删除这里的SET latin1,乱码ok啦~

这里思维散发下,就能发现MySQL的一个特点:
默认情况下,字段的字符编码与表的字符编码相同
也可以单独为字段指定其他字符编码

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值