mysql以utf8存储gbk输出的实现--

mysql以utf8存储gbk输出的实现--

ID:22680801

大小:58.00 KB

页数:6页

时间:2018-10-30

mysql以utf8存储gbk输出的实现--_第1页
mysql以utf8存储gbk输出的实现--_第2页
mysql以utf8存储gbk输出的实现--_第3页
mysql以utf8存储gbk输出的实现--_第4页
mysql以utf8存储gbk输出的实现--_第5页
资源描述:

《mysql以utf8存储gbk输出的实现--》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

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

2、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代码:  

3、程序代码  <?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);    mysql_query(SET  CHARACTER  SE

4、T  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_select_db($this->db_name,  $this->db_lin

5、k);    //  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->db_link);    return  true;    }    ?>  需要注意几点:  1.m

6、ysql必须把gbk,gb2312,utf8等字符集编译进去。  2.入库的数据内容必须保证是最正确的UTF8编码。  3.存储和读取操作要指定正确的字符集进行连接校对。  要是前端代码操作数据入库不能以UTF8进行,则需要对字符进行转码了。(例如用AJAX提交的数据便是正确的UTF8,这时是不用转换的。)  因为mb_string是PHP所支持字符最全的,而iconv比它稍差一点,mb_string并不能完全支持一些特殊字符的转码,所以目前为止都没有完美的转码方法。  再次对mb_string和iconv进行比较:  m

7、b_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);>>>>这篇文章来自..,。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。