繁体   English   中英

无法在MySQL表中插入♥字符

[英]Cannot insert ♥ character in MySQL table

我试图用PHP将♥插入MySQL表。 它来自输入字段。

表的字符集是utf8_general_ci,在PHP中我使用mysql_query("SET NAMES 'utf8'"); 在连接之后立即。

但♥只是变成'?' 插入时

我也尝试从phpMyAdmin插入♥到表中,但它返回此错误:

Warning: #1366 Incorrect string value: '\xE2\x99\xA5' for column 'subject' at row 1

结果也是'?' 而不是♥。

有什么原因可以解释这个问题?

这是因为在表的列上定义了不兼容的字符集和排序规则

尝试表或列的字符集更改UTF8

ALTER TABLE table_name CONVERT TO CHARACTER SET utf8;

要么

ALTER TABLE table_name MODIFY col VARCHAR(255) CHARACTER SET utf8; 

试试这个:

ini_set('default_charset', 'utf-8');

在你的php文件中并设置:

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

并在你的数据库中chek到utf8_general_ci

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM