0

0

php增删改查报错1366怎么办_数据类型不匹配解决【详解】

星夢妙者

星夢妙者

发布时间:2026-01-03 22:10:02

|

520人浏览过

|

来源于php中文网

原创

错误1366本质是MySQL字符集不匹配导致编码转换失败,需统一客户端、连接、表字段三层utf8mb4字符集及utf8mb4_unicode_ci排序规则,并确保PHP文件、HTML输出、表单提交全链路UTF-8一致。

php增删改查报错1366怎么办_数据类型不匹配解决【详解】

PHP 增删改查报错 1366,本质是 MySQL 的字符集/排序规则不匹配导致的编码转换失败,不是 PHP 本身的问题,但常在 PDO 或 mysqli 执行 INSERTUPDATE 时突然暴露。核心解决路径是统一「客户端→连接→表字段」三层字符集,而非只改 PHP 或只改数据库。

为什么 1366 错误总在插入中文时出现?

MySQL 报错 Incorrect string value: '\xE4\xBD\xA0\xE5\xA5\xBD' for column 'name' at row 1(对应错误号 1366)说明:客户端发来的是 UTF-8 编码字节(如“你好”为 \xE4\xBD\xA0\xE5\xA5\xBD),但目标列实际定义为 latin1utf8(非 utf8mb4),无法存入 4 字节 UTF-8 字符(如 emoji、生僻汉字)。

  • utf8 在 MySQL 中实际是 utf8mb3,最多支持 3 字节 UTF-8 字符,不兼容 emoji 和部分 Unicode 4.0+ 汉字
  • utf8mb4 才是真正的 UTF-8,支持全部 Unicode 字符
  • PHP 连接默认字符集若没显式设置,可能回落为 latin1,哪怕页面和数据库都标称 “UTF-8”

PHP 连接层必须显式设置 utf8mb4

仅在 MySQL 配置文件里改 character-set-server=utf8mb4 不够,PHP 连接初始化时未声明,仍会用旧字符集通信。

/* PDO 示例:dsn 中必须带 charset,且 setAttribute 不足以覆盖 */
$dsn = 'mysql:host=localhost;dbname=test;charset=utf8mb4';
$pdo = new PDO($dsn, $user, $pass, [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
    PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci"
]);

/ mysqli 示例 / $mysqli = new mysqli('localhost', $user, $pass, 'test'); $mysqli->set_charset('utf8mb4'); // 必须调用,不能只靠配置文件

  • DSN 中 charset=utf8mb4 是必需项,漏掉会导致连接层仍用 latin1
  • PDO::MYSQL_ATTR_INIT_COMMAND 是保险策略,防止某些中间件或连接池重置字符集
  • mysqli::set_charset() 必须在 new mysqli() 后立即调用,晚于查询则无效

表结构和字段必须是 utf8mb4 + utf8mb4_unicode_ci

即使连接正确,如果表或字段定义仍是 utf8latin1,写入仍会触发 1366

Magician
Magician

Figma插件,AI生成图标、图片和UX文案

下载

立即学习PHP免费学习笔记(深入)”;

-- 查看当前字段字符集
SHOW CREATE TABLE users;

-- 安全升级整张表(含所有字段和索引) ALTER TABLE users CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

-- 单独修改某字段(如 name 字段太长导致索引超限,需先调小长度) ALTER TABLE users MODIFY name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

  • CONVERT TO 会重写所有字段,但对已有数据做隐式转换,有风险,建议先备份
  • 使用 utf8mb4 后,InnoDB 索引长度限制从 767 字节减为 191 字符(因 4 字节/字符),VARCHAR(255) 可能需改为 VARCHAR(191)
  • 不要用 utf8mb4_general_ci,它已废弃,排序行为不一致,一律用 utf8mb4_unicode_ciutf8mb4_0900_as_cs(MySQL 8.0+)

PHP 文件与 HTML 输出也要保持一致

如果 PHP 脚本文件本身保存为 GBK,或输出时没设 header,浏览器可能用错误编码解析 POST 数据,导致传入 MySQL 的已是乱码字节。

  • PHP 源文件必须用 UTF-8 无 BOM 编码保存(编辑器可设,默认 Notepad++ 会偷偷加 BOM)
  • 输出 HTML 前加:header('Content-Type: text/html; charset=utf-8');
  • HTML 中必须有:
  • 表单提交accept-charset="utf-8"

真正卡住人的地方,往往不是某一层错了,而是连接设了 utf8mb4,表却还是 utf8;或者表改了,但某个 TEXT 字段的 collation 没同步更新;又或者 PDO 连上了,但用了 mysql_query() 旧扩展——它根本不读 DSN 里的 charset 参数。每层都要单独验证,不能假设“设过一次就全通”。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2521

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1599

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1493

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1416

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 793人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号