mysql+gbk存储_MySQL_Mysql以utf8存储gbk输出的实现方法提供,一个站有可能经历gb2312(gbk,big5) - phpStudy...

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

一个站有可能经历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);相关阅读:

phpmyadmin里面导入sql语句格式的大量数据的方法

Screen Ruler:GNOME桌面屏幕标尺

linux文件系统基础知识

php几种生成随机密码的方法

Web服务器负载均衡方案

CSS网页设计 把HTML标记分类

系统资源管理软件TreeSize轻松管理磁盘空间

PHP生成静态页

Oracle中实现圆周率计算(三

Prototype ObjectRange对象学习

数据库中聚簇索引与非聚簇索引的区别[图文]

MYSQL教程:MYSQL启动与退出以及链接故障恢复

IE6图片加载的一个BUG解决方法

弹出提示的效果代码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值