(1)建立資料庫時不指定字符集會繼承伺服器字符集 server characterset: utf8 db characterset: latin1 mysqlgt; show g
(1)建立資料庫時不指定字符集會繼承伺服器字符集
server characterset: utf8
db characterset: latin1
mysql> show global variables like 'character_set_database';
| variable_name | value |
| character_set_database | latin1 |
1 row in set (0.00 sec)
mysql> create database mytest2;
query ok, 1 row affected (0.02 sec)
mysql> show create database mytest2;
| database | create database |
| mytest2 | create database `mytest2` /*!40100 default character set utf8 */ |
1 row in set (0.00 sec)
可見,建立資料庫時,若沒有指定字符集,那麼會繼承伺服器的字符集,不受character_set_database值的影響。
--------------------------------------分割線 --------------------------------------
ubuntu 14.04下安裝mysql
《mysql權威指南(原書第2版)》清晰中文掃瞄版 pdf
ubuntu 14.04 lts 安裝 lnmp nginx\php5 (php-fpm)\mysql
ubuntu 14.04下搭建mysql主從伺服器
ubuntu 12.04 lts 構建高可用分布式 mysql 集群
ubuntu 12.04下源**安裝mysql5.6以及python-mysqldb
mysql-5.5.38通用二進位制安裝
--------------------------------------分割線 --------------------------------------
(2)表建立不指定字符集時會繼承資料庫字符集
mysql> create database mytest1 charset=latin1;
query ok, 1 row affected (0.04 sec)
mysql> show create database mytest1;
| database | create database |
| mytest1 | create database `mytest1` /*!40100 default character set latin1 */ | ## 這個可以看到,資料庫的字符集為latin1
1 row in set (0.00 sec)
mysql> use mytest1
database changed
mysql> create table t(id int,name char(20)); ## 建立表t時沒有指定字符集
query ok, 0 rows affected (0.13 sec)
mysql> show create table t\g
*************************** 1. row ***************************
table: t
create table: create table `t` (
`id` int(11) default null,
`name` char(20) default null
) engine=innodb default charset=latin1
1 row in set (0.00 sec)
可見,建立表時沒有指定字符集,,那麼會繼承資料庫的字符集。
(3)建立表時,欄位不指定字符集,則預設繼承表的字符集
mysql> show create database mytest1;
| database | create database |
| mytest1 | create database `mytest1` /*!40100 default character set latin1 */ |
1 row in set (0.00 sec)
mysql> create table t3(id int,name char(20) character set utf8,text char(30));
query ok, 0 rows affected (0.15 sec)
mysql> show create table t3\g
*************************** 1. row ***************************
table: t3
create table: create table `t3` (
`id` int(11) default null,
`name` char(20) character set utf8 default null,
`text` char(30) default null
) engine=innodb default charset=latin1
1 row in set (0.00 sec)
可見,如果表建立時,欄位不指定字符集,欄位的字符集就會繼承表的字符集。
mysql 集群字符集 Mysql 字符集
字符集與字元比較 字符集字符集是某種字元的集合,比如最常見的ascii碼,由127個字元組成,只需要乙個位元組就能表示 我們常說的字符集還是gbk iso utf8 mysql 我們使用得最多的字符集就是gbk 和 utf8了 他們都是變長字符集,如果字元在ascii範圍內就使用乙個位元組表示,其他...
mysql字符集 MySQL字符集選擇
一 怎樣選擇合適的字符集 對mysql資料庫來說,字符集很重要,因為資料庫儲存的資料大部分都是各種文字,字符集對資料庫的儲存,處理效能都會有所影響。主要考慮一下幾方面的因素 1.滿足應用支援語言的需求,應用處理各種各樣的文字,發布到使用不同語言的國家或地區,可以選擇unicode字符集,mysql的...
mysql字符集修改 MySql字符集修改
問題分析 普通的字串或者表情都是佔位3個位元組,所以utf8足夠用了,但是移動端的表情符號佔位是4個位元組,普通的utf8就不夠用了,為了應對無線網際網路的機遇和挑戰 避免 emoji 表情符號帶來的問題 涉及無線相關的 mysql 資料庫建議都提前採用 utf8mb4 字符集,這必須要作為移動網際...