php – 无法在MySQL中存储UTF8字符

找不到我无法在MySQL数据库中存储像ţ,î,ş这样的字符的原因.

我的表定义是:

CREATE TABLE IF NOT EXISTS `gen_admin_words_translated` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `word_id` int(10) NOT NULL,
  `value` text COLLATE utf8_unicode_ci,
  `lang_id` int(2) NOT NULL,
  `needUpd` int(1) NOT NULL DEFAULT '1',
  PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=2689 ;

使用以下脚本完成与数据库的连接:

$charset = "UTF8";
$link = MysqL_connect($host, $user, $pass);
if(!$link){
    die("Unable to connect to database server.");
}
MysqL_selectdb($database);
if(function_exists("MysqL_set_charset")){
    MysqL_set_charset($charset, $link);
}else{
    MysqL_query("SET NAMES $charset");   
}

我在页面的头部:

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

并且脚本是:

$text = 'ţ, î, ş';
MysqL_query("insert into gen_admin_words_translated (word_id, lang_id, value, needUpd) values (1, 1, '$text', 1)");

我在表中最后得到的是:

SELECT * FROM  `gen_admin_words_translated` 

id   word_id value lang_id needUpd
5166 1034    ?,    1       1

解决方法:

将我的评论扩展为答案:

您似乎已正确设置了内容,并且只是在将字符串文字插入数据库时​​才会停留.要成功完成此操作,还必须确保已保存的PHP脚本的文本编码也是UTF-8.

大多数体面的编辑器会让你知道你正在使用哪种编码,也可以保存(即转换)不同的编码(甚至记事本今天这样做).但是,作为快速检查,您可以将字符€添加到您的文件中并保存.如果文件大小改变1或2个字节而不是3,则不是UTF-8,您需要将文件转换为该编码.

除此之外,当从浏览器接收文本作为输入时,您的代码应该处理它就好了.

注意:使用< Meta>时用于设置页面编码的标记应该足够了,如果使用PHP的HTTP标头执行此操作会更好,如下所示:

header('Content-type: text/html; charset=utf-8');

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...