欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【Mysql中用utf8存储而用gbk输出的实现】,下面是详细的分享!
Mysql中用utf8存储而用gbk输出的实现
一个站有可能经历gb2312(gbk,big5)到utf8的转换过程,其中会遇到很多的问题。站点太庞大了怎么办呢,只能一步步来了。要是能在极少改动前端代码的情况下,先完成数据的转换将会使整件事情容易得多。经过几天测试终于发现,Mysql以utf8存储gbk输出是可以实现的。mysql4.1后都有个特性,可以指定当前客户端连接所使用的字符集,mysql默认都是latin1,或由mysql server端配置的字符集进行连接校对。我使用utf8_general_ci来创建字段。
DB:
SQL代码:
程序代码
|
Create TABLE `table` ( `id` INT( 10 ) NOT NULL , `name` VARCHAR( 50 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , INDEX ( `g_id` ) ) ENGINE=innodb CHARACTER SET utf8 COLLATE utf8_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输出的实现,下面是编辑为你推荐的有价值的用户互动:
相关问题:编程中如何存储和处理中文,是否要用到gbk编码或者...
答:private function loaderHandler(event:*):void { switch(event.type) { case Event.COMPLETE: trace(_loader.data.result); break; case Event.OPEN: trace("open: " + event); break; case ProgressEvent.PROGRESS: trace("progress: " + even... >>详细
相关问题:将UTF8转成GBK , 我要保存到MYSQL数据库(GBK)
答:如果是文本文件的话可以在windows系统下用记事本打开然后另存为你想要的文本格式。如果想更进一步的实现自动化改变编码的话建议你去学习字符的编码吧。这样你就能写出转换编码的程序了。 >>详细
相关问题:如何将mysql数据库文件由GBK编码转为UTF8编码?
答:MySQL中的表 数据原来是GBK 就是GBK的编码 变成UTF8 的途径就是重新导出数据 在导入 并将 my.ini 中的配置文件改为: 两个default-character-set 依次设置为 default-character-set=UTF-8 default-character-set=GBK >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
