MySQL以utf8存储gbk输出的实现方法提供

2022-11-12 09:19:28
内容摘要
这篇文章主要为大家详细介绍了MySQL以utf8存储gbk输出的实现方法提供,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔记做的技术笔记!一个站有可能经历gb2
文章正文

这篇文章主要为大家详细介绍了MySQL以utf8存储gbk输出的实现方法提供,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

一个站有可能经历gb2312(gbk,big5)到utf8的转换过程,其中会遇到很多的问题。站点太庞大了怎么办呢,只能一步步来了。要是能在极少改动前端代码的情况下,先完成数据的转换将会使整件事情容易得多。经过几天测试终于发现,Mysql以utf8存储gbk输出是可以实现的。mysql4.1后都有个特性,可以指定当前客户端连接所使用的字符集,mysql默认都是latin1,或由mysqlserver端配置的字符集进行连接校对。我使用utf8_general_ci来创建字段。DB:SQL代码:

代码如下:


CreateTABLE`table`( 
`id`INT(10)NOTNULL, 
`name`VARCHAR(50)CHARACTERSETutf8COLLATEutf8_general_ciNOTNULL, 
INDEX(`g_id`) 
)ENGINE=innodbCHARACTERSETutf8COLLATEutf8_general_ci;
PHP:存储操作指定使用utf8字符集进行连接校对,读取操作指定使用gbk字符集进行连接校对。PHP代码:

代码如下:


<?php 
//SelectDBAndSetLinkUseUTF8 
function_select_db_utf() 
{ 
mysql_select_db($this->db_name,$this->db_link); 


//initcharacter 
mysql_query("SETNAMESutf8",$this->db_link); 
mysql_query("SETCHARACTERSETutf8",$this->db_link); 
mysql_query("SETCOLLATION_CONNECTION='utf8_general_ci'",$this->db_link); 


returntrue; 
} 


//SelectDBAndSetLinkUseGBK 
function_select_db_gb() 
{ 
mysql_select_db($this->db_name,$this->db_link); 


//initcharacter 
mysql_query("SETNAMESgbk",$this->db_link); 
mysql_query("SETCHARACTERSETgbk",$this->db_link); 
mysql_query("SETCOLLATION_CONNECTION='gbk_chinese_ci'",$this->db_link); 


returntrue; 
} 
?>
需要注意几点:1.mysql必须把gbk,gb2312,utf8等字符集编译进去。2.入库的数据内容必须保证是最正确的UTF8编码。3.存储和读取操作要指定正确的字符集进行连接校对。要是前端代码操作数据入库不能以UTF8进行,则需要对字符进行转码了。(例如用AJAX提交的数据便是正确的UTF8,这时是不用转换的。)因为mb_string是PHP所支持字符最全的,而iconv比它稍差一点,mb_string并不能完全支持一些特殊字符的转码,所以目前为止都没有完美的转码方法。再次对mb_string和iconv进行比较:mb_string:1.所支持字符最全2.内容自动识别编码,不需要确定原来字符的编码,但是执行效率比iconv差太多3.$content=mb_convert_encoding($content,"UTF-8","GBK,GB2312,BIG5");(顺序不同效果也有差异)iconv:1.所支持字符不全2.需要确定原来字符的编码,但在确定编码的情况下执行效率比mb_convert_encoding高3.$content=iconv("GBK","UTF-8",$content);

注:关于MySQL以utf8存储gbk输出的实现方法提供的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!