找不到我无法在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');