MySQL 1366 - Incorrect string value:错误

MySQL 1366 - Incorrect string value:错误

错误

如何发生

在给MySQL添加数据的时候发生了下面的错误

mysql 复制代码
insert into sys_dept values(100,  0,   '0',          '若依科技',   0, '若依', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null)
> 1366 - Incorrect string value: '\xE8\x8B\xA5\xE4\xBE\x9D...' for column 'dept_name' at row 1
> 时间: 0.002s 

发生原因:

无法正确存储中文字符,这通常是由于字符集配置不完整导致的

解决方法

第一种尝试

直接复制粘贴下面的代码就行

记得将数据库名换成你的数据库名称

sql 复制代码
ALTER DATABASE 数据库名 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; 
set character_set_database = utf8mb4
set character_set_server = utf8mb4
set character_set_results = utf8mb4
set character_set_connection= utf8mb4
set character_set_client = utf8mb4 

第二种尝试

打开 my.ini配置

我默认的是这样的:

sql 复制代码
[mysql]
default-character-set=utf8 
[mysqld]
basedir=D:\MySQL\mysql-5.7.18-winx64
datadir=D:\MySQL\mysql-5.7.18-winx64\data
port=3306
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
secure_file_priv=default-time_zone = '+8:00'

后面我改成这样就成功了:

sql 复制代码
[client]
#default-character-set=utf8mb4
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
[mysql]
default-character-set=utf8mb4

[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
basedir=D:\MySQL\mysql-5.7.18-winx64
datadir=D:\MySQL\mysql-5.7.18-winx64\data
port=3306
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
secure_file_priv=
default-time_zone='+8:00'
max_connections=200
innodb_buffer_pool_size=1G
log-error=mysql-error.log
相关推荐
荣光波比1 小时前
MySQL数据库(八)—— MySQL全量+增量备份方案:从脚本开发到连锁餐饮场景落地
运维·数据库·mysql·云计算
qq_340474026 小时前
3.0 labview使用SQLServer
数据库·sqlserver·labview
靡樊7 小时前
MySQL:C语言链接
数据库·mysql
一只游鱼7 小时前
linux使用yum安装数据库
linux·mysql·adb
路上^_^9 小时前
安卓基础组件023-SharedPerferences
android
gopher95119 小时前
go中的Ticker
数据库·golang
熏鱼的小迷弟Liu9 小时前
【MySQL】一篇讲透MySQL的MVCC机制!
数据库·mysql
恋猫de小郭9 小时前
Fluttercon EU 2025 :Let‘s go far with Flutter
android·开发语言·flutter·ios·golang
key0611 小时前
网络安全等级保护测评实施过程
数据库·安全·web安全·安全合规
程序猿阿伟11 小时前
《政企API网关:安全与性能平衡的转型实践》
网络·数据库·安全