一个站有可能经历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. 存储和读取操作要指定正确的字符集进行连接校对。

要是前端代码操作数据入库不能以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 存储utf8_Mysql以utf8存储gbk输出的实现方法相关推荐

  1. mysql 存储 emoji_MySQL 中如何存储 emoji ?

    问题还原 使用 erlang 存储一些特殊字符串到 MySQL 的时候,却没法读出来.经检查,这些字符串的二进制格式如下: <<240,159,152,134,240,159,152,14 ...

  2. mysql gbk编码 字节数_MySql中UTF8和GBK编码中文字符长度问题

    2.设计函数,输入为一个字符串,里边包含中文.英文.数字等字符,编码为GBK.中文字符的编码规则假定为:双字节组成,高字节大于0x80,低字节任意.     a) 用常用语言(c/c++/php/ja ...

  3. mysql utf8 gbk_MySql中UTF8 和 GBK 编码中文字符长度问题

    为什么要了解MySql中UTF8 和 GBK 编码中文字符长度呢?举个例子,在oracle中用utf8 字段中文长度为1的话,需要char(3),mysql中则是char(1),如果你按照oracle ...

  4. MYSQL数据库默认latin1字符集转换为GBK或UTF8

    可以采用下面的方法latin1字符集转换为gbk字符集或utf8字符集.具体的转换步骤如下: 一.latin1转gbk 1.导出数据库 mysqldump --default-character-se ...

  5. mysql 存储xml类型_(MariaDB)MySQL数据类型详解和存储机制

    1.1 数据类型概览 数据类型算是一种字段约束,它限制每个字段能存储什么样的数据.能存储多少数据.能存储的格式等.MySQL/MariaDB大致有5类数据类型,分别是:整形.浮点型.字符串类型.日期时 ...

  6. cmd mysql utf8_MySQL中UTF8编码的数据在cmd下乱码

    花了一下午,解决MySQL在Windows的cmd下中文乱码的问题. mysql> use abc; Database changed mysql> select * from schoo ...

  7. mysql存储表情字符_MySQL 存储表情字符

    摘要 在 MySQL 中直接存储表情的时候,会出现无法插入数据的错误. 这是由于一般情况下,MySQL 的字符集是 utf8,而对于 emoji 表情的 mysql 的 utf8 字符集是不支持,需要 ...

  8. 看完就懂——MySQL索引、事务与存储引擎

    目录 前言 一.索引(index) 1.1 索引的概念 1.2 索引的作用 1.3 索引的优缺点 1.4 索引的分类 1.5 创建索引的原则依据 1.6 创建索引 1.6.1 普通索引 1.6.2 唯 ...

  9. MySQL初级篇——存储过程、存储函数的相关概念及应用举例

    文章目录: 1.什么是存储过程? 2.存储过程操作相关SQL 3.存储过程实操SQL 4.存储函数操作相关SQL 5.存储函数实操SQL 6.存储过程.存储函数的优缺点 1.什么是存储过程? 含义:存 ...

最新文章

  1. 我都陪你坐了一天了,你好歹说句话啊!吖的,谱也忒大了。。。
  2. 解构亚马逊Alexa的1.5万种技能
  3. mysql了解jdbc_JDBC的连接mySql的基本知识
  4. 经典插花的教训 PKU 1157
  5. React Native使用指南-原生模块
  6. java 虚拟内存 堆_jvm虚拟内存分布 与 GC算法
  7. SAS Viya应用简介
  8. Ubuntu下BOINC服务器安装(step8失败)
  9. iOS开发之alloc底层探索之旅
  10. 编程之美---电梯调度算法
  11. 产品经理学习——卡诺模型
  12. 基于JAVA汽车客运站票务管理系统计算机毕业设计源码+数据库+lw文档+系统+部署
  13. 中文和英语中主语、谓语、宾语、定语、状语、补语的定义
  14. 一元三次方程c语言程序,求解一元三次方程近似解的几种算法(C语言)
  15. 图解Topo拓扑排序
  16. matlab 数学形态学,数学形态学matlab程序
  17. 如何在PowerPoint中更改文本的大小写
  18. 如何优雅的在 Word 中插入代码,PlanetB 的完美替代方案
  19. 虚拟机下载安装Centos7(新手详解)
  20. Gibonacci number【斐波拉契】

热门文章

  1. windows端,C/S端自动化测试工具比较
  2. 计算机高级工考试题库2018,维修电工高级工试题题库2018
  3. 数据集成框架SeaTunnel学习笔记
  4. 计算机无信号然后黑屏,电脑开机显示无信号,然后黑屏,为什么
  5. C语言文件操作:获取文件中文本的大小(长度)
  6. Git安装失败 报The drive or UNC share you
  7. QQ2010正式版下载
  8. express设置favicon
  9. Pdftoword:最精准的pdf to word文件转换器
  10. 【P1369】矩形(贪心)