服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|

服务器之家 - 数据库 - Mysql - Mysql以utf8存储gbk输出的实现方法提供

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

2019-10-18 16:35mysql技术网 Mysql

一个站有可能经历gb2312(gbk,big5)到utf8的转换过程,其中会遇到很多的问题。站点太庞大了怎么办呢,只能一步步来了。要是能在极少改动前端代码的情况下,先完成数据的转换将会使整件事情容易得多。经过几天测试终于发现,M

一个站有可能经历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   
        //    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    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_select_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->db_link);   


        return    true;   
        }   
?>  

需要注意几点: 
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使用MySQL的geometry类型处理经纬度距离问题的方法

    使用MySQL的geometry类型处理经纬度距离问题的方法

    这篇文章主要介绍了使用MySQL的geometry类型处理经纬度距离问题的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    Shawn4812019-06-09
  • MysqlMySQL分页Limit的优化过程实战

    MySQL分页Limit的优化过程实战

    在mysql中进行分页查询时,一般会使用limit查询,下面这篇文章主要给大家介绍了关于MySQL分页Limit优化的相关资料,文中通过示例代码介绍的非常详细,需...

    旧梦发癫2252019-06-27
  • Mysqlmysql修改数据库默认路径无法启动问题的解决

    mysql修改数据库默认路径无法启动问题的解决

    这篇文章主要给大家介绍了关于mysql修改数据库默认路径无法启动问题的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的...

    hellyhe1372019-06-18
  • MysqlMysql5.7修改root密码教程

    Mysql5.7修改root密码教程

    今天小编就为大家分享一篇关于Mysql5.7修改root密码教程,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看...

    炫酷飞扬2112019-06-04
  • MysqlMySQL优化全攻略-相关数据库命令

    MySQL优化全攻略-相关数据库命令

    接下来我们要讨论的是数据库性能优化的另一方面,即运用数据库服务器内建的工具辅助性能分析和优化。 ...

    mysql教程网2912019-10-15
  • MysqlMysql树形递归查询的实现方法

    Mysql树形递归查询的实现方法

    这篇文章主要给大家介绍了关于Mysql树形递归查询的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    javahih2602019-06-06
  • Mysqlmysql中影响数据库性能的因素讲解

    mysql中影响数据库性能的因素讲解

    在本篇文章中我们给大家讲述了mysql中影响性能的因素以及相关知识点内容,有兴趣的朋友参考下。...

    laozhang1902019-06-23
  • Mysql数据库sql语句优化

    数据库sql语句优化

    今天小编就为大家分享一篇关于数据库sql语句优化,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    qq_431937971622019-06-11