微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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');

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐