MySql 编码设置实际应用代码示例

php中文网
发布: 2016-06-07 16:11:49
原创
1191人浏览过

以下的文章主要讲述的是MySql 编码设置的实际操作步骤,我们大家都知道MySQL 4.1的实际应用字符集所支持(Character Set Support)主要有2个方面:即,字符集(Character set)与其实际的排序方式(Collation)。 对于实际应用的相关字符集的支持细化到四个层次:

以下的文章主要讲述的是mysql 编码设置的实际操作步骤,我们大家都知道mysql 4.1的实际应用字符集所支持(character set support)主要有2个方面:即,字符集(character set)与其实际的排序方式(collation)。

对于实际应用的相关字符集的支持细化到四个层次:

服务器(server),数据库(database),数据表(table)和连接(connection)。

查看系统的字符集和排序方式的设定可以通过下面的两条命令或mysql> status 。

<ol class="dp-xml"><li class="alt"><span><span>mysql</span><span class="tag">></span><span> SHOW VARIABLES LIKE 'character_set_%';   </span></span></li><li><span>+--------------------------+----------------------------+   </span></li><li class="alt"><span>| Variable_name | Value |   </span></li><li><span>+--------------------------+----------------------------+   </span></li><li class="alt"><span>| character_set_client | latin1 |   </span></li><li><span>| character_set_connection | latin1 |   </span></li><li class="alt"><span>| character_set_database | latin1 |   </span></li><li><span>| character_set_results | latin1 |   </span></li><li class="alt"><span>| character_set_server | latin1 |   </span></li><li><span>| character_set_system | utf8 |   </span></li><li class="alt"><span>| character_sets_dir | /usr/share/mysql/charsets/ |   </span></li><li><span>+--------------------------+----------------------------+   </span></li><li class="alt"><span>7 rows in set (0.00 sec)   </span></li><li><span> </span></li><li class="alt"><span>mysql</span><span class="tag">></span><span> SHOW VARIABLES LIKE 'collation_%';   </span></li><li><span>+----------------------+-------------------+   </span></li><li class="alt"><span>| Variable_name | Value |   </span></li><li><span>+----------------------+-------------------+   </span></li><li class="alt"><span>| collation_connection | latin1_swedish_ci |   </span></li><li><span>| collation_database | latin1_swedish_ci |   </span></li><li class="alt"><span>| collation_server | latin1_swedish_ci |   </span></li><li><span>+----------------------+-------------------+   </span></li><li class="alt"><span>3 rows in set (0.00 sec)  </span></li></ol>
登录后复制

上面列出的值就是系统的默认值。(很奇怪系统怎么默认是latin1的瑞典语排序方式)...

当我们按照原来的方式通过PHP存取MySQL数据库时,就算设置了表的默认字符集为utf8并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在这个connection连接层上。MySql 编码设置解决方法是在发送查询前执行一下下面这句:

初阶PHP Apache MySQL网站设计
初阶PHP Apache MySQL网站设计

初阶PHP Apache MySQL网站设计来自作者多年学习、应用和讲授PHP的经验与体会,是专为学习PHP+MySQL数据库编程人员编与的入门教材。在最后二章设计了2个贴近实际应用的典型案例:留言本系统和论坛系统,每个案例先介绍开发思路、步骤,再给出全部源代码,使所学内容与实际应用紧密结合,特别是论坛系统将全书的案例串讲起来,力求使读者学到最贴近应用前沿的知识和技能。

初阶PHP Apache MySQL网站设计 389
查看详情 初阶PHP Apache MySQL网站设计

1.SET NAMES 'utf8';

它相当于下面的三句指令:

<ol class="dp-xml"><li class="alt"><span><span>SET </span><span class="attribute">character_set_client</span><span> = </span><span class="attribute-value">utf8</span><span>;   </span></span></li><li><span>SET </span><span class="attribute">character_set_results</span><span> = </span><span class="attribute-value">utf8</span><span>;   </span></li><li class="alt"><span>SET </span><span class="attribute">character_set_connection</span><span> = </span><span class="attribute-value">utf8</span><span>;  </span></li></ol>
登录后复制

2. 创建数据库

<ol class="dp-xml"><li class="alt"><span><span>mysql</span><span class="tag">></span><span> create database name character set utf8;  </span></span></li></ol>
登录后复制

3. 创建表

<ol class="dp-xml"><li class="alt"><span><span>CREATE TABLE `type` (   </span></span></li><li><span>`id` int(10) unsigned NOT NULL auto_increment,   </span></li><li class="alt"><span>`flag_deleted` enum('Y','N') character set utf8 NOT NULL default 'N',   </span></li><li><span>`flag_type` int(5) NOT NULL default '0',   </span></li><li class="alt"><span>`type_name` varchar(50) character set utf8 NOT NULL default '',   </span></li><li><span>PRIMARY KEY (`id`)   </span></li><li class="alt"><span>) DEFAULT </span><span class="attribute">CHARSET</span><span>=</span><span class="attribute-value">utf8</span><span>;  </span></li></ol>
登录后复制

4. 修改数据库成utf8的.

<ol class="dp-xml"><li class="alt"><span><span>mysql</span><span class="tag">></span><span> alter database name character set utf8;  </span></span></li></ol>
登录后复制

5. 修改表默认用utf8.

<ol class="dp-xml"><li class="alt"><span><span>mysql</span><span class="tag">></span><span> alter table type character set utf8;  </span></span></li></ol>
登录后复制

6. 修改字段用utf8

 

<ol class="dp-xml"><li class="alt"><span><span>mysql</span><span class="tag">></span><span> alter table type modify type_name varchar(50) CHARACTER SET utf8;  </span></span></li></ol>
登录后复制

以上的相关内容就是对MySql 编码设置的介绍,望你能有所收获。


相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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