香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > MYSQL >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

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


时间:2020-11-02 13:24 作者:admin610456


一个站有可能经历gb2312(gbk,big5)到utf8的转换过程,其中会遇到很多的问题。站点太庞大了怎么办呢,只能一步步来了。要是能在极少改动前端代码的情况下,先完成数据的转换将会使整件事情容易得多。经过几天测试终于发现,mysql/' target='_blank'>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); (责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)