mysql 繼承 MySQL字符集繼承關係驗證

2021-10-18 21:40:43 字數 2807 閱讀 5307

(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 字符集,這必須要作為移動網際...