• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL以utf8存储gbk输出的实现_MySQL

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论

一个站有可能经历gb2312(gbk,big5)到utf8的转换过程,其中会遇到很多的问题。本文来源gao@!dai!ma.com搞$$代^@码!网!站点太庞大了怎么办呢,只能一步步来了。要是能在极少改动前端代码的情况下,先完成数据的转换将会使整件事情容易得多。经过几天测试终于发现,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);


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL以utf8存储gbk输出的实现_MySQL
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址