0

0

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

php中文网

php中文网

发布时间:2016-06-01 14:00:26

|

805人浏览过

|

来源于php中文网

原创

一个站有可能经历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代码:

  程序代码

    
  //  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. 存储和读取操作要指定正确的字符集进行连接校对。

Android传感器编程 中文WORD版
Android传感器编程 中文WORD版

本文档主要讲述的是Android传感器编程;传感器是一种物理装置或生物器官,能够探测、感受外界的信号、物理条件(如光、热、湿度)或化学组成(如烟雾),并将探知的信息传递给其它装置或器官。同时也可以说传感器是一种检测装置,能感受被测量的信息,并能将检测的感受到的信息,按一定规律变换成为电信号或其它所需形式的信息输出,以满足信息的传输、处理、存储、显示、记录和控制等要求。它是实现自动检测和自动控制的首要环节。感兴趣的朋友可以过来看看

下载

  要是前端代码操作数据入库不能以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);

相关专题

更多
C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

29

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

55

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

时间管理,自律给我自由
时间管理,自律给我自由

共5课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号