首頁 資料庫 mysql教程 MySql 编码设置实际应用代码示例

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

Jun 07, 2016 pm 04:11 PM
mysql 程式碼 實際 應用 文章 範例 編碼 設定

以下的文章主要讲述的是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 编码设置解决方法是在发送查询前执行一下下面这句:

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 编码设置的介绍,望你能有所收获。


本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP 的大數據結構處理技巧 PHP 的大數據結構處理技巧 May 08, 2024 am 10:24 AM

PHP 的大數據結構處理技巧

如何優化 PHP 中的 MySQL 查詢效能? 如何優化 PHP 中的 MySQL 查詢效能? Jun 03, 2024 pm 08:11 PM

如何優化 PHP 中的 MySQL 查詢效能?

如何在 PHP 中使用 MySQL 備份和還原? 如何在 PHP 中使用 MySQL 備份和還原? Jun 03, 2024 pm 12:19 PM

如何在 PHP 中使用 MySQL 備份和還原?

如何使用 PHP 插入資料到 MySQL 表? 如何使用 PHP 插入資料到 MySQL 表? Jun 02, 2024 pm 02:26 PM

如何使用 PHP 插入資料到 MySQL 表?

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 Dec 09, 2024 am 11:42 AM

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤

如何在 PHP 中使用 MySQL 預存程序? 如何在 PHP 中使用 MySQL 預存程序? Jun 02, 2024 pm 02:13 PM

如何在 PHP 中使用 MySQL 預存程序?

如何使用 PHP 建立 MySQL 表? 如何使用 PHP 建立 MySQL 表? Jun 04, 2024 pm 01:57 PM

如何使用 PHP 建立 MySQL 表?

清華大學與智譜AI重磅開源 GLM-4:掀起自然語言處理新革命 清華大學與智譜AI重磅開源 GLM-4:掀起自然語言處理新革命 Jun 12, 2024 pm 08:38 PM

清華大學與智譜AI重磅開源 GLM-4:掀起自然語言處理新革命

See all articles