资源描述:
《mysql以utf8存储gbk输出的实现》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、Mysql以utf8存储gbk输出的实现>>教育资源库 一个站有可能经历gb2312(gbk,big5)到utf8的转换过程,其中会遇到很多的问题。站点太庞大了怎么办呢,只能一步步来了。要是能在极少改动前端代码的情况下,先完成数据的转换将会使整件事情容易得多。经过几天测试终于发现,Mysql以utf8存储gbk输出是可以实现的。mysql4.1后都有个特性,可以指定当前客户端连接所使用的字符集,mysql默认都是latin1,或由mysqlserver端配置的字符集进行连接校对。我使用utf8_gen
2、eral_ci来创建字段。 DB: SQL代码: 程序代码 CreateTABLE`table`( `id`INT(10)NOTNULL, `name`VARCHAR(50)CHARACTERSETutf8COLLATEutf8_general_ciNOTNULL, INDEX(`g_id`) )ENGINE=innodbCHARACTERSETutf8COLLATEutf8_general_ci; PHP: 存储操作指定使用utf8字符集进行连接校对,读取操作指定
3、使用gbk字符集进行连接校对。 PHP代码: 程序代码 <?php // Select DB And Set Link Use UTF8 function _select_db_utf() { mysql_select_db($this->db_name, $this->db_link); // init character mysql_query(SET NAMES utf8, $this->db_link)
4、; mysql_query(SET CHARACTER SET utf8, $this->db_link); mysql_query(SET COLLATION_CONNECTION=utf8_general_ci, $this->db_link); return true; } // Select DB And Set Link Use GBK function _select_db_gb() { mysql_s
5、elect_db($this->db_name, $this->db_link); // init character mysql_query(SET NAMES gbk, $this->db_link); mysql_query(SET CHARACTER SET gbk, $this->db_link); mysql_query(SET COLLATION_CONNECTION=gbk_chinese_ci, $this->
6、;db_link); return true; } ?> 需要注意几点: 1.mysql必须把gbk,gb2312,utf8等字符集编译进去。 2.入库的数据内容必须保证是最正确的UTF8编码。 3.存储和读取操作要指定正确的字符集进行连接校对。 要是前端代码操作数据入库不能以UTF8进行,则需要对字符进行转码了。(例如用AJAX提交的数据便是正确的UTF8,这时是不用转换的。) 因为mb_string是PHP所支持字符最全的,而iconv比它稍差一点,mb_str
7、ing并不能完全支持一些特殊字符的转码,所以目前为止都没有完美的转码方法。 再次对mb_string和iconv进行比较: mb_string: 1.所支持字符最全 2.内容自动识别编码,不需要确定原来字符的编码,但是执行效率比iconv差太多 3.$content=mb_convert_encoding($content,UTF-8,GBK,GB2312,BIG5);(顺序不同效果也有差异) iconv: 1.所支持字符不全 2.需要确定原来字符的编码,但在确定编码的情况下执行效率比m
8、b_convert_encoding高 3.$content=iconv(GBK,UTF-8,$content);>>>>这篇文章来自..,。