日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

MySQL-数据类型

發(fā)布時(shí)間:2025/7/25 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL-数据类型 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

閱讀目錄

一 介紹

二 數(shù)值類型

三 日期類型

四 字符串類型

五 枚舉類型與集合類型

一 介紹

存儲(chǔ)引擎決定了表的類型,而表內(nèi)存放的數(shù)據(jù)也要有不同的類型,每種數(shù)據(jù)類型都有自己的寬度,但寬度是可選的

詳細(xì)參考:

  • http://www.runoob.com/mysql/mysql-data-types.html
  • http://dev.mysql.com/doc/refman/5.7/en/data-type-overview.html

mysql常用數(shù)據(jù)類型概覽

#1. 數(shù)字: 整型:tinyinit int bigint小數(shù):float :在位數(shù)比較短的情況下不精準(zhǔn)double :在位數(shù)比較長的情況下不精準(zhǔn)0.000001230123123123存成:0.000001230000decimal:(如果用小數(shù),則用推薦使用decimal)精準(zhǔn)內(nèi)部原理是以字符串形式去存#2. 字符串:char(10):簡單粗暴,浪費(fèi)空間,存取速度快root存成root000000varchar:精準(zhǔn),節(jié)省空間,存取速度慢sql優(yōu)化:創(chuàng)建表時(shí),定長的類型往前放,變長的往后放比如性別 比如地址或描述信息>255個(gè)字符,超了就把文件路徑存放到數(shù)據(jù)庫中。比如圖片,視頻等找一個(gè)文件服務(wù)器,數(shù)據(jù)庫中只存路徑或url。#3. 時(shí)間類型: 最常用:datetime#4. 枚舉類型與集合類型

?

二 數(shù)值類型

1、整數(shù)類型

整數(shù)類型:TINYINT SMALLINT MEDIUMINT INT BIGINT

作用:存儲(chǔ)年齡,等級(jí),id,各種號(hào)碼等

========================================tinyint[(m)] [unsigned] [zerofill]小整數(shù),數(shù)據(jù)類型用于保存一些范圍的整數(shù)數(shù)值范圍:有符號(hào):-128 ~ 127無符號(hào): ~ 255PS: MySQL中無布爾值,使用tinyint(1)構(gòu)造========================================int[(m)][unsigned][zerofill]整數(shù),數(shù)據(jù)類型用于保存一些范圍的整數(shù)數(shù)值范圍:有符號(hào):-2147483648 ~ 2147483647無符號(hào): ~ 4294967295========================================bigint[(m)][unsigned][zerofill]大整數(shù),數(shù)據(jù)類型用于保存一些范圍的整數(shù)數(shù)值范圍:有符號(hào):-9223372036854775808 ~ 9223372036854775807無符號(hào):~ 18446744073709551615

?

=========有符號(hào)和無符號(hào)tinyint========== #tinyint默認(rèn)為有符號(hào) MariaDB [db1]> create table t1(x tinyint); #默認(rèn)為有符號(hào),即數(shù)字前有正負(fù)號(hào) MariaDB [db1]> desc t1; MariaDB [db1]> insert into t1 values-> (-129),-> (-128),-> (127),-> (128); MariaDB [db1]> select * from t1; +------+ | x | +------+ | -128 | #-129存成了-128 | -128 | #有符號(hào),最小值為-128 | 127 | #有符號(hào),最大值127 | 127 | #128存成了127 +------+#設(shè)置無符號(hào)tinyint MariaDB [db1]> create table t2(x tinyint unsigned); MariaDB [db1]> insert into t2 values-> (-1),-> (0),-> (255),-> (256); MariaDB [db1]> select * from t2; +------+ | x | +------+ | 0 | -1存成了0 | 0 | #無符號(hào),最小值為0 | 255 | #無符號(hào),最大值為255 | 255 | #256存成了255 +------+============有符號(hào)和無符號(hào)int============= #int默認(rèn)為有符號(hào) MariaDB [db1]> create table t3(x int); #默認(rèn)為有符號(hào)整數(shù) MariaDB [db1]> insert into t3 values-> (-2147483649),-> (-2147483648),-> (2147483647),-> (2147483648); MariaDB [db1]> select * from t3; +-------------+ | x | +-------------+ | -2147483648 | #-2147483649存成了-2147483648 | -2147483648 | #有符號(hào),最小值為-2147483648 | 2147483647 | #有符號(hào),最大值為2147483647 | 2147483647 | #2147483648存成了2147483647 +-------------+#設(shè)置無符號(hào)int MariaDB [db1]> create table t4(x int unsigned); MariaDB [db1]> insert into t4 values-> (-1),-> (0),-> (4294967295),-> (4294967296); MariaDB [db1]> select * from t4; +------------+ | x | +------------+ | 0 | #-1存成了0 | 0 | #無符號(hào),最小值為0 | 4294967295 | #無符號(hào),最大值為4294967295 | 4294967295 | #4294967296存成了4294967295 +------------+==============有符號(hào)和無符號(hào)bigint============= MariaDB [db1]> create table t6(x bigint); MariaDB [db1]> insert into t5 values -> (-9223372036854775809),-> (-9223372036854775808),-> (9223372036854775807),-> (9223372036854775808);MariaDB [db1]> select * from t5; +----------------------+ | x | +----------------------+ | -9223372036854775808 | | -9223372036854775808 | | 9223372036854775807 | | 9223372036854775807 | +----------------------+MariaDB [db1]> create table t6(x bigint unsigned); MariaDB [db1]> insert into t6 values -> (-1),-> (0),-> (18446744073709551615),-> (18446744073709551616);MariaDB [db1]> select * from t6; +----------------------+ | x | +----------------------+ | 0 | | 0 | | 18446744073709551615 | | 18446744073709551615 | +----------------------+======用zerofill測(cè)試整數(shù)類型的顯示寬度============= MariaDB [db1]> create table t7(x int(3) zerofill); MariaDB [db1]> insert into t7 values-> (1),-> (11),-> (111),-> (1111); MariaDB [db1]> select * from t7; +------+ | x | +------+ | 001 | | 011 | | 111 | | 1111 | #超過寬度限制仍然可以存 +------+ 驗(yàn)證

?

整型中的M值

1、整數(shù)型的數(shù)值類型已經(jīng)限制了取值范圍,有符號(hào)整型和無符號(hào)整型都有,而M值并不代表可以存儲(chǔ)的數(shù)值字符長度,它代表的是數(shù)據(jù)在顯示時(shí)顯示的最小長度;2、當(dāng)存儲(chǔ)的字符長度超過M值時(shí),沒有任何的影響,只要不超過數(shù)值類型限制的范圍;3、當(dāng)存儲(chǔ)的字符長度小于M值時(shí),只有在設(shè)置了zerofill用0來填充,才能夠看到效果,換句話就是說,沒有zerofill,M值就是無用的。總結(jié):int(11),tinyint(1),bigint(20),后面的數(shù)字,不代表占用空間容量。而代表最小顯示位數(shù)。這個(gè)東西基本沒有意義,除非你對(duì)字段指定zerofill。所以我們?cè)谠O(shè)計(jì)mysql數(shù)據(jù)庫時(shí),建表時(shí),mysql會(huì)自動(dòng)分配長度:int(11)、tinyint(4)、smallint(6)、mediumint(9)、bigint(20)。所以,就用這些默認(rèn)的顯示長度就可以了。不用再去自己填長度,比如搞個(gè)int(10)、tinyint(1)之類的,基本沒用。而且導(dǎo)致表的字段類型多樣化。

?

?

注意:為該類型指定寬度時(shí),僅僅只是指定查詢結(jié)果的顯示寬度,與存儲(chǔ)范圍無關(guān),存儲(chǔ)范圍如下

其實(shí)我們完全沒必要為整數(shù)類型指定顯示寬度,使用默認(rèn)的就可以了

默認(rèn)的顯示寬度,都是在最大值的基礎(chǔ)上加1

?

?

類型大小范圍(有符號(hào))范圍(無符號(hào))用途
TINYINT1 字節(jié)(-128,127)(0,255)小整數(shù)值
SMALLINT2 字節(jié)(-32 768,32 767)(0,65 535)大整數(shù)值
MEDIUMINT3 字節(jié)(-8 388 608,8 388 607)(0,16 777 215)大整數(shù)值
INT或INTEGER4 字節(jié)(-2 147 483 648,2 147 483 647)(0,4 294 967 295)大整數(shù)值
BIGINT8 字節(jié)(-9 233 372 036 854 775 808,9 223 372 036 854 775 807)(0,18 446 744 073 709 551 615)極大整數(shù)值

int的存儲(chǔ)寬度是4個(gè)Bytes,即32個(gè)bit,即2**32

無符號(hào)最大值為:4294967296-1

有符號(hào)最大值:2147483648-1

有符號(hào)和無符號(hào)的最大數(shù)字需要的顯示寬度均為10,而針對(duì)有符號(hào)的最小值則需要11位才能顯示完全,所以int類型默認(rèn)的顯示寬度為11是非常合理的

最后:整形類型,其實(shí)沒有必要指定顯示寬度,使用默認(rèn)的就ok

?

2、浮點(diǎn)型

定點(diǎn)數(shù)類型 ?DEC等同于DECIMAL  

浮點(diǎn)類型:FLOAT DOUBLE

作用:存儲(chǔ)薪資、身高、體重、體質(zhì)參數(shù)等

====================================== #FLOAT[(M,D)] [UNSIGNED] [ZEROFILL] 定義:單精度浮點(diǎn)數(shù)(非準(zhǔn)確小數(shù)值),m是數(shù)字總個(gè)數(shù),d是小數(shù)點(diǎn)后個(gè)數(shù)。m最大值為255,d最大值為30有符號(hào):-3.402823466E+38 to -1.175494351E-38,1.175494351E-38 to 3.402823466E+38 無符號(hào):1.175494351E-38 to 3.402823466E+38精確度: **** 隨著小數(shù)的增多,精度變得不準(zhǔn)確 ****====================================== #DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL] 定義:雙精度浮點(diǎn)數(shù)(非準(zhǔn)確小數(shù)值),m是數(shù)字總個(gè)數(shù),d是小數(shù)點(diǎn)后個(gè)數(shù)。m最大值為255,d最大值為30有符號(hào):-1.7976931348623157E+308 to -2.2250738585072014E-3082.2250738585072014E-308 to 1.7976931348623157E+308無符號(hào):2.2250738585072014E-308 to 1.7976931348623157E+308精確度:****隨著小數(shù)的增多,精度比float要高,但也會(huì)變得不準(zhǔn)確 ****====================================== decimal[(m[,d])] [unsigned] [zerofill]定義:準(zhǔn)確的小數(shù)值,m是數(shù)字總個(gè)數(shù)(負(fù)號(hào)不算),d是小數(shù)點(diǎn)后個(gè)數(shù)。 m最大值為65,d最大值為30精確度:**** 隨著小數(shù)的增多,精度始終準(zhǔn)確 ****對(duì)于精確數(shù)值計(jì)算時(shí)需要用此類型decaimal能夠存儲(chǔ)精確值的原因在于其內(nèi)部按照字符串存儲(chǔ)。

?

mysql> create table t1(x float(256,31)); ERROR 1425 (42000): Too big scale 31 specified for column 'x'. Maximum is 30. mysql> create table t1(x float(256,30)); ERROR 1439 (42000): Display width out of range for column 'x' (max = 255) mysql> create table t1(x float(255,30)); #建表成功 Query OK, 0 rows affected (0.02 sec)mysql> create table t2(x double(255,30)); #建表成功 Query OK, 0 rows affected (0.02 sec)mysql> create table t3(x decimal(66,31)); ERROR 1425 (42000): Too big scale 31 specified for column 'x'. Maximum is 30. mysql> create table t3(x decimal(66,30)); ERROR 1426 (42000): Too-big precision 66 specified for 'x'. Maximum is 65. mysql> create table t3(x decimal(65,30)); #建表成功 Query OK, 0 rows affected (0.02 sec)mysql> show tables; +---------------+ | Tables_in_db1 | +---------------+ | t1 | | t2 | | t3 | +---------------+ rows in set (0.00 sec)mysql> insert into t1 values(1.1111111111111111111111111111111); #小數(shù)點(diǎn)后31個(gè)1 Query OK, 1 row affected (0.01 sec)mysql> insert into t2 values(1.1111111111111111111111111111111); Query OK, 1 row affected (0.00 sec)mysql> insert into t3 values(1.1111111111111111111111111111111); Query OK, 1 row affected, 1 warning (0.01 sec)mysql> select * from t1; #隨著小數(shù)的增多,精度開始不準(zhǔn)確 +----------------------------------+ | x | +----------------------------------+ | 1.111111164093017600000000000000 | +----------------------------------+ row in set (0.00 sec)mysql> select * from t2; #精度比float要準(zhǔn)確點(diǎn),但隨著小數(shù)的增多,同樣變得不準(zhǔn)確 +----------------------------------+ | x | +----------------------------------+ | 1.111111111111111200000000000000 | +----------------------------------+ row in set (0.00 sec)mysql> select * from t3; #精度始終準(zhǔn)確,d為30,于是只留了30位小數(shù) +----------------------------------+ | x | +----------------------------------+ | 1.111111111111111111111111111111 | +----------------------------------+ row in set (0.00 sec) 驗(yàn)證 類型大小范圍(有符號(hào))范圍(無符號(hào))用途
FLOAT4 字節(jié)(-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38)0,(1.175 494 351 E-38,3.402 823 466 E+38)單精度
浮點(diǎn)數(shù)值
DOUBLE8 字節(jié)(-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)雙精度
浮點(diǎn)數(shù)值
DECIMAL?依賴于M和D的值依賴于M和D的值小數(shù)值

?

?

3、位類型(了解)

BIT(M)可以用來存放多位二進(jìn)制數(shù),M范圍從1~64,如果不寫默認(rèn)為1位。
注意:對(duì)于位字段需要使用函數(shù)讀取
? ? bin()顯示為二進(jìn)制
? ? hex()顯示為十六進(jìn)制

MariaDB [db1]> create table t9(id bit); MariaDB [db1]> desc t9; #bit默認(rèn)寬度為1 +-------+--------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+--------+------+-----+---------+-------+ | id | bit(1) | YES | | NULL | | +-------+--------+------+-----+---------+-------+MariaDB [db1]> insert into t9 values(8); MariaDB [db1]> select * from t9; #直接查看是無法顯示二進(jìn)制位的 +------+ | id | +------+ | | +------+ MariaDB [db1]> select bin(id),hex(id) from t9; #需要轉(zhuǎn)換才能看到 +---------+---------+ | bin(id) | hex(id) | +---------+---------+ | 1 | 1 | +---------+---------+MariaDB [db1]> alter table t9 modify id bit(5); MariaDB [db1]> insert into t9 values(8); MariaDB [db1]> select bin(id),hex(id) from t9; +---------+---------+ | bin(id) | hex(id) | +---------+---------+ | 1 | 1 | | 1000 | 8 | +---------+---------+ 驗(yàn)證

?

三 日期類型

DATE TIME DATETIME?TIMESTAMP YEAR?

作用:存儲(chǔ)用戶注冊(cè)時(shí)間,文章發(fā)布時(shí)間,員工入職時(shí)間,出生時(shí)間,過期時(shí)間等

?

類型大小
(字節(jié))范圍格式用途
DATE31000-01-01/9999-12-31YYYY-MM-DD日期值
TIME3'-838:59:59'/'838:59:59'HH:MM:SS時(shí)間值或持續(xù)時(shí)間
YEAR11901/2155YYYY年份值
DATETIME81000-01-01 00:00:00/9999-12-31 23:59:59YYYY-MM-DD HH:MM:SS混合日期和時(shí)間值
TIMESTAMP4

1970-01-01 00:00:00/2038

結(jié)束時(shí)間是第?2147483647?秒,北京時(shí)間?2038-1-19 11:14:07,格林尼治時(shí)間 2038年1月19日 凌晨 03:14:07

YYYYMMDD HHMMSS混合日期和時(shí)間值,時(shí)間戳
YEARYYYY(1901/2155)DATEYYYY-MM-DD(1000-01-01/9999-12-31)TIMEHH:MM:SS('-838:59:59'/'838:59:59')DATETIMEYYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)TIMESTAMPYYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某時(shí))

?

============year=========== MariaDB [db1]> create table t10(born_year year); #無論year指定何種寬度,最后都默認(rèn)是year(4) MariaDB [db1]> insert into t10 values -> (1900),-> (1901),-> (2155),-> (2156); MariaDB [db1]> select * from t10; +-----------+ | born_year | +-----------+ | 0000 | | 1901 | | 2155 | | 0000 | +-----------+============date,time,datetime=========== MariaDB [db1]> create table t11(d date,t time,dt datetime); MariaDB [db1]> desc t11; +-------+----------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+----------+------+-----+---------+-------+ | d | date | YES | | NULL | | | t | time | YES | | NULL | | | dt | datetime | YES | | NULL | | +-------+----------+------+-----+---------+-------+MariaDB [db1]> insert into t11 values(now(),now(),now()); MariaDB [db1]> select * from t11; +------------+----------+---------------------+ | d | t | dt | +------------+----------+---------------------+ | 2017-07-25 | 16:26:54 | 2017-07-25 16:26:54 | +------------+----------+---------------------+============注意啦,注意啦,注意啦===========1. 單獨(dú)插入時(shí)間時(shí),需要以字符串的形式,按照對(duì)應(yīng)的格式插入 MariaDB [db1]> insert into t11 values("1900-01-01","19:00:00","1900-01-01 19:00:00");============timestamp=========== MariaDB [db1]> create table t12(time timestamp); MariaDB [db1]> insert into t12 values(); MariaDB [db1]> insert into t12 values(null); MariaDB [db1]> select * from t12; +---------------------+ | time | +---------------------+ | 2017-07-25 16:29:17 | | 2017-07-25 16:30:01 | +---------------------+============注意啦,注意啦,注意啦===========1. 插入年份時(shí),盡量使用4位值 2. 插入兩位年份時(shí),<=69,以20開頭,比如50, 結(jié)果2050 >=70,以19開頭,比如71,結(jié)果1971 MariaDB [db1]> create table t12(y year); MariaDB [db1]> insert into t12 values -> (50),-> (71); MariaDB [db1]> select * from t12; +------+ | y | +------+ | 2050 | | 1971 | +------+============綜合練習(xí)=========== MariaDB [db1]> create table student(-> id int,-> name varchar(20),-> born_year year,-> birth date,-> class_time time,-> reg_time datetime);MariaDB [db1]> insert into student values-> (1,'alex',"1995","1995-11-11","11:11:11","2017-11-11 11:11:11"),-> (2,'egon',"1997","1997-12-12","12:12:12","2017-12-12 12:12:12"),-> (3,'wsb',"1998","1998-01-01","13:13:13","2017-01-01 13:13:13");MariaDB [db1]> select * from student; +------+------+-----------+------------+------------+---------------------+ | id | name | born_year | birth | class_time | reg_time | +------+------+-----------+------------+------------+---------------------+ | 1 | alex | 1995 | 1995-11-11 | 11:11:11 | 2017-11-11 11:11:11 | | 2 | egon | 1997 | 1997-12-12 | 12:12:12 | 2017-12-12 12:12:12 | | 3 | wsb | 1998 | 1998-01-01 | 13:13:13 | 2017-01-01 13:13:13 | +------+------+-----------+------------+------------+---------------------+ 驗(yàn)證

??

在實(shí)際應(yīng)用的很多場(chǎng)景中,MySQL的這兩種日期類型都能夠滿足我們的需要,存儲(chǔ)精度都為秒,但在某些情況下,會(huì)展現(xiàn)出他們各自的優(yōu)劣。下面就來總結(jié)一下兩種日期類型的區(qū)別。1.DATETIME的日期范圍是1001——9999年,TIMESTAMP的時(shí)間范圍是1970——2038年。2.DATETIME存儲(chǔ)時(shí)間與時(shí)區(qū)無關(guān),TIMESTAMP存儲(chǔ)時(shí)間與時(shí)區(qū)有關(guān),顯示的值也依賴于時(shí)區(qū)。在mysql服務(wù)器,操作系統(tǒng)以及客戶端連接都有時(shí)區(qū)的設(shè)置。3.DATETIME使用8字節(jié)的存儲(chǔ)空間,TIMESTAMP的存儲(chǔ)空間為4字節(jié)。因此,TIMESTAMP比DATETIME的空間利用率更高。4.DATETIME的默認(rèn)值為null;TIMESTAMP的字段默認(rèn)不為空(not null),默認(rèn)值為當(dāng)前時(shí)間(CURRENT_TIMESTAMP),如果不做特殊處理,并且update語句中沒有指定該列的更新值,則默認(rèn)更新為當(dāng)前時(shí)間。 datetime與timestamp的區(qū)別

??

四 字符串類型

#官網(wǎng):https://dev.mysql.com/doc/refman/5.7/en/char.html #注意:char和varchar括號(hào)內(nèi)的參數(shù)指的都是字符的長度#char類型:定長,簡單粗暴,浪費(fèi)空間,存取速度快字符長度范圍:0-255(一個(gè)中文是一個(gè)字符,是utf8編碼的3個(gè)字節(jié))存儲(chǔ):存儲(chǔ)char類型的值時(shí),會(huì)往右填充空格來滿足長度例如:指定長度為10,存>10個(gè)字符則報(bào)錯(cuò),存<10個(gè)字符則用空格填充直到湊夠10個(gè)字符存儲(chǔ)檢索:在檢索或者說查詢時(shí),查出的結(jié)果會(huì)自動(dòng)刪除尾部的空格,除非我們打開pad_char_to_full_length SQL模式(SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)#varchar類型:變長,精準(zhǔn),節(jié)省空間,存取速度慢字符長度范圍:0-65535(如果大于21845會(huì)提示用其他類型 。mysql行最大限制為65535字節(jié),字符編碼為utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)存儲(chǔ):varchar類型存儲(chǔ)數(shù)據(jù)的真實(shí)內(nèi)容,不會(huì)用空格填充,如果'ab ',尾部的空格也會(huì)被存起來強(qiáng)調(diào):varchar類型會(huì)在真實(shí)數(shù)據(jù)前加1-2Bytes的前綴,該前綴用來表示真實(shí)數(shù)據(jù)的bytes字節(jié)數(shù)(1-2Bytes最大表示65535個(gè)數(shù)字,正好符合mysql對(duì)row的最大字節(jié)限制,即已經(jīng)足夠使用)如果真實(shí)的數(shù)據(jù)<255bytes則需要1Bytes的前綴(1Bytes=8bit 2**8最大表示的數(shù)字為255)如果真實(shí)的數(shù)據(jù)>255bytes則需要2Bytes的前綴(2Bytes=16bit 2**16最大表示的數(shù)字為65535)檢索:尾部有空格會(huì)保存下來,在檢索或者說查詢時(shí),也會(huì)正常顯示包含空格在內(nèi)的內(nèi)容 類型大小用途
CHAR0-255字節(jié)定長字符串
VARCHAR0-65535 字節(jié)變長字符串
TINYBLOB0-255字節(jié)不超過 255 個(gè)字符的二進(jìn)制字符串
TINYTEXT0-255字節(jié)短文本字符串
BLOB0-65 535字節(jié)二進(jìn)制形式的長文本數(shù)據(jù)
TEXT0-65 535字節(jié)長文本數(shù)據(jù)
MEDIUMBLOB0-16 777 215字節(jié)二進(jìn)制形式的中等長度文本數(shù)據(jù)
MEDIUMTEXT0-16 777 215字節(jié)中等長度文本數(shù)據(jù)
LONGBLOB0-4 294 967 295字節(jié)二進(jìn)制形式的極大文本數(shù)據(jù)
LONGTEXT0-4 294 967 295字節(jié)極大文本數(shù)據(jù)

?

#官網(wǎng):https://dev.mysql.com/doc/refman/5.7/en/char.html CHAR 和 VARCHAR 是最常使用的兩種字符串類型。 一般來說 CHAR(N)用來保存固定長度的字符串,對(duì)于 CHAR 類型,N 的范圍 為 0 ~ 255 VARCHAR(N)用來保存變長字符類型,對(duì)于 VARCHAR 類型,N 的范圍為 0 ~ 65 535 CHAR(N)和 VARCHAR(N) 中的 N 都代表字符長度,而非字節(jié)長度。 ps:對(duì)于 MySQL 4.1 之前的版本,如 MySQL 3.23 和 MySQL 4.0,CHAR(N)和 VARCHAR (N)中的 N 代表字節(jié)長度。#CHAR類型 對(duì)于 CHAR 類型的字符串,MySQL 數(shù)據(jù)庫會(huì)自動(dòng)對(duì)存儲(chǔ)列的右邊進(jìn)行填充(Right Padded)操作,直到字符串達(dá)到指定的長度 N。而在讀取該列時(shí),MySQL 數(shù)據(jù)庫會(huì)自動(dòng)將 填充的字符刪除。有一種情況例外,那就是顯式地將 SQL_MODE 設(shè)置為 PAD_CHAR_TO_ FULL_LENGTH,例如: mysql> CREATE TABLE t ( a CHAR(10));Query OK, 0 rows affected (0.03 sec) mysql> INSERT INTO t SELECT 'abc';Query OK, 1 row affected (0.03 sec)Records: 1 Duplicates: 0 Warnings: 0 mysql> SELECT a,HEX(a),LENGTH(a) FROM t\G;*************************** 1. row ***************************a: abcHEX(a): 616263LENGTH (a): 3 row in set (0.00 sec)mysql> SET SQL_MODE='PAD_CHAR_TO_FULL_LENGTH';Query OK, 0 rows affected (0.00 sec) mysql> SELECT a,HEX(a),LENGTH(a) FROM t\G;*************************** 1. row ***************************a: abcHEX(a): 61626320202020202020LENGTH (a): 10 row in set (0.00 sec)在上述這個(gè)例子中,先創(chuàng)建了一張表 t,a 列的類型為 CHAR(10)。然后通過 INSERT語句插入值“abc”,因?yàn)?a 列的類型為 CHAR 型,所以會(huì)自動(dòng)在后面填充空字符串,使其長 度為 10。接下來在通過 SELECT 語句取出數(shù)據(jù)時(shí)會(huì)將 a 列右填充的空字符移除,從而得到 值“abc”。通過 LENGTH 函數(shù)看到 a 列的字符長度為 3 而非 10。 接著我們將 SQL_MODE 顯式地設(shè)置為 PAD_CHAR_TO_FULL_LENGTH。這時(shí)再通過 SELECT 語句進(jìn)行查詢時(shí),得到的結(jié)果是“abc ”,abc 右邊有 7 個(gè)填充字符 0x20,并通 過 HEX 函數(shù)得到了驗(yàn)證。這次 LENGTH 函數(shù)返回的長度為 10。需要注意的是,LENGTH 函數(shù)返回的是字節(jié)長度,而不是字符長度。對(duì)于多字節(jié)字符集,CHAR(N)長度的列最多 可占用的字節(jié)數(shù)為該字符集單字符最大占用字節(jié)數(shù) *N。例如,對(duì)于 utf8 下,CHAR(10)最 多可能占用 30 個(gè)字節(jié)。通過對(duì)多字節(jié)字符串使用 CHAR_LENGTH 函數(shù)和 LENGTH 函數(shù), 可以發(fā)現(xiàn)兩者的不同,示例如下: mysql> SET NAMES gbk;Query OK, 0 rows affected (0.03 sec) mysql> SELECT @a:='MySQL 技術(shù)內(nèi)幕 ';Query OK, 0 rows affected (0.03 sec) mysql> SELECT @a,HEX(@a),LENGTH(@a),CHAR_LENGTH(@a)\G; ***************************** 1. row **************************** a: MySQL 技術(shù)內(nèi)幕 HEX(a): 4D7953514CBCBCCAF5C4DAC4BB LENGTH (a): 13 CHAR_LENGTH(a): 9 row in set (0.00 sec)變 量 @ a 是 g b k 字 符 集 的 字 符 串 類 型 , 值 為 “ M y S Q L 技 術(shù) 內(nèi) 幕 ”, 十 六 進(jìn) 制 為 0x4D7953514CBCBCCAF5C4DAC4BB,LENGTH 函數(shù)返回 13,即該字符串占用 13 字節(jié), 因?yàn)?gbk 字符集中的中文字符占用兩個(gè)字節(jié),因此一共占用 13 字節(jié)。CHAR_LENGTH 函數(shù) 返回 9,很顯然該字符長度為 9#VARCHAR類型 VARCHAR 類型存儲(chǔ)變長字段的字符類型,與 CHAR 類型不同的是,其存儲(chǔ)時(shí)需要在 前綴長度列表加上實(shí)際存儲(chǔ)的字符,該字符占用 1 ~ 2 字節(jié)的空間。當(dāng)存儲(chǔ)的字符串長度小 于 255 字節(jié)時(shí),其需要 1 字節(jié)的空間,當(dāng)大于 255 字節(jié)時(shí),需要 2 字節(jié)的空間。所以,對(duì) 于單字節(jié)的 latin1 來說,CHAR(10)和 VARCHAR(10)最大占用的存儲(chǔ)空間是不同的, CHAR(10)占用 10 個(gè)字節(jié)這是毫無疑問的,而 VARCHAR(10)的最大占用空間數(shù)是 11 字節(jié),因?yàn)槠湫枰?1 字節(jié)來存放字符長度。 ------------------------------------------------- 注意 對(duì)于有些多字節(jié)的字符集類型,其 CHAR 和 VARCHAR 在存儲(chǔ)方法上是一樣的,同樣 需要為長度列表加上字符串的值。對(duì)于 GBK 和 UTF-8 這些字符類型,其有些字符是以 1 字節(jié) 存放的,有些字符是按 2 或 3 字節(jié)存放的,因此同樣需要 1 ~ 2 字節(jié)的空間來存儲(chǔ)字符的長 度。 ------------------------------------------------- 雖然 CHAR 和 VARCHAR 的存儲(chǔ)方式不太相同,但是對(duì)于兩個(gè)字符串的比較,都只比 較其值,忽略 CHAR 值存在的右填充,即使將 SQL _MODE 設(shè)置為 PAD_CHAR_TO_FULL_ LENGTH 也一樣,例如: mysql> CREATE TABLE t ( a CHAR(10), b VARCHAR(10));Query OK, 0 rows affected (0.01 sec) mysql> INSERT INTO t SELECT 'a','a';Query OK, 1 row affected (0.00 sec)Records: 1 Duplicates: 0 Warnings: 0 mysql> SELECT a=b FROM t\G;*************************** 1. row ***************************a=b: 1 row in set (0.00 sec)mysql> SET SQL_MODE='PAD_CHAR_TO_FULL_LENGTH';Query OK, 0 rows affected (0.00 sec) mysql> SELECT a=b FROM t\G;*************************** 1. row ***************************a=b: 1 row in set (0.00 sec) 官網(wǎng)詳解

?

?

ValueCHAR(4)Storage RequiredVARCHAR(4)Storage Required
'''????'4 bytes''1 byte
'ab''ab??'4 bytes'ab'3 bytes
'abcd''abcd'4 bytes'abcd'5 bytes
'abcdefgh''abcd'4 bytes'abcd'5 bytes

?

測(cè)試前了解兩個(gè)函數(shù) length:查看字節(jié)數(shù) char_length:查看字符數(shù)

1. char填充空格來滿足固定長度,但是在查詢時(shí)卻會(huì)很不要臉地刪除尾部的空格(裝作自己好像沒有浪費(fèi)過空間一樣),然后修改sql_mode讓其現(xiàn)出原形

mysql> create table t1(x char(5),y varchar(5)); Query OK, 0 rows affected (0.26 sec)#char存5個(gè)字符,而varchar存4個(gè)字符 mysql> insert into t1 values('你瞅啥 ','你瞅啥 '); Query OK, 1 row affected (0.05 sec)mysql> SET sql_mode=''; Query OK, 0 rows affected, 1 warning (0.00 sec)#在檢索時(shí)char很不要臉地將自己浪費(fèi)的2個(gè)字符給刪掉了,裝的好像自己沒浪費(fèi)過空間一樣,而varchar很老實(shí),存了多少,就顯示多少 mysql> select x,char_length(x),y,char_length(y) from t1; +-----------+----------------+------------+----------------+ | x | char_length(x) | y | char_length(y) | +-----------+----------------+------------+----------------+ | 你瞅啥 | 3 | 你瞅啥 | 4 | +-----------+----------------+------------+----------------+ row in set (0.00 sec)#略施小計(jì),讓char現(xiàn)出原形 mysql> SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH'; Query OK, 0 rows affected (0.00 sec)#這下子char原形畢露了...... mysql> select x,char_length(x),y,char_length(y) from t1; +-------------+----------------+------------+----------------+ | x | char_length(x) | y | char_length(y) | +-------------+----------------+------------+----------------+ | 你瞅啥 | 5 | 你瞅啥 | 4 | +-------------+----------------+------------+----------------+ row in set (0.00 sec)#char類型:3個(gè)中文字符+2個(gè)空格=11Bytes #varchar類型:3個(gè)中文字符+1個(gè)空格=10Bytes mysql> select x,length(x),y,length(y) from t1; +-------------+-----------+------------+-----------+ | x | length(x) | y | length(y) | +-------------+-----------+------------+-----------+ | 你瞅啥 | 11 | 你瞅啥 | 10 | +-------------+-----------+------------+-----------+ row in set (0.00 sec) View Code

?

?了解concat

mysql> select concat('數(shù)據(jù): ',x,'長度: ',char_length(x)),concat(y,char_length(y) ) from t1; +------------------------------------------------+--------------------------+ | concat('數(shù)據(jù): ',x,'長度: ',char_length(x)) | concat(y,char_length(y)) | +------------------------------------------------+--------------------------+ | 數(shù)據(jù): 你瞅啥 長度: 5 | 你瞅啥 4 | +------------------------------------------------+--------------------------+ row in set (0.00 sec)

?

2. 雖然 CHAR 和 VARCHAR 的存儲(chǔ)方式不太相同,但是對(duì)于兩個(gè)字符串的比較,都只比 較其值,忽略 CHAR 值存在的右填充,即使將 SQL _MODE 設(shè)置為 PAD_CHAR_TO_FULL_ LENGTH 也一樣,,但這不適用于like

Values in CHAR and VARCHAR columns are sorted and compared according to the character set collation assigned to the column.All MySQL collations are of type PAD SPACE. This means that all CHAR, VARCHAR, and TEXT values are compared without regard to any trailing spaces. “Comparison” in this context does not include the LIKE pattern-matching operator, for which trailing spaces are significant. For example:mysql> CREATE TABLE names (myname CHAR(10)); Query OK, 0 rows affected (0.03 sec)mysql> INSERT INTO names VALUES ('Monty'); Query OK, 1 row affected (0.00 sec)mysql> SELECT myname = 'Monty', myname = 'Monty ' FROM names; +------------------+--------------------+ | myname = 'Monty' | myname = 'Monty ' | +------------------+--------------------+ | 1 | 1 | +------------------+--------------------+ row in set (0.00 sec)mysql> SELECT myname LIKE 'Monty', myname LIKE 'Monty ' FROM names; +---------------------+-----------------------+ | myname LIKE 'Monty' | myname LIKE 'Monty ' | +---------------------+-----------------------+ | 1 | 0 | +---------------------+-----------------------+ row in set (0.00 sec)

?

3. 總結(jié)

#常用字符串系列:char與varchar 注:雖然varchar使用起來較為靈活,但是從整個(gè)系統(tǒng)的性能角度來說,char數(shù)據(jù)類型的處理速度更快,有時(shí)甚至可以超出varchar處理速度的50%。因此,用戶在設(shè)計(jì)數(shù)據(jù)庫時(shí)應(yīng)當(dāng)綜合考慮各方面的因素,以求達(dá)到最佳的平衡#其他字符串系列(效率:char>varchar>text) TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT BLOB 系列 TINYBLOB BLOB MEDIUMBLOB LONGBLOB BINARY系列 BINARY VARBINARYtext:text數(shù)據(jù)類型用于保存變長的大字符串,可以組多到65535 (2**16 ? 1)個(gè)字符。 mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 ? 1) characters. longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 ? 1) characters.

五 枚舉類型與集合類型

字段的值只能在給定范圍中選擇,如單選框,多選框
enum 單選 只能在給定的范圍內(nèi)選一個(gè)值,如性別 sex 男male/女female
set 多選 在給定的范圍內(nèi)可以選擇一個(gè)或一個(gè)以上的值(愛好1,愛好2,愛好3...)

枚舉類型(enum)An ENUM column can have a maximum of 65,535 distinct elements. (The practical limit is less than 3000.)示例:CREATE TABLE shirts (name VARCHAR(40),size ENUM('x-small', 'small', 'medium', 'large', 'x-large'));INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');集合類型(set)A SET column can have a maximum of 64 distinct members.示例:CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d'); 驗(yàn)證

MariaDB [db1]> create table consumer( -> name varchar(50),-> sex enum('male','female'),-> level enum('vip1','vip2','vip3','vip4','vip5'), #在指定范圍內(nèi),多選一-> hobby set('play','music','read','study') #在指定范圍內(nèi),多選多-> );MariaDB [db1]> insert into consumer values -> ('egon','male','vip5','read,study'),-> ('alex','female','vip1','girl'); #注意,注意,沒有g(shù)irlMariaDB [db1]> select * from consumer; +------+--------+-------+------------+ | name | sex | level | hobby | +------+--------+-------+------------+ | egon | male | vip5 | read,study | | alex | female | vip1 | | +------+--------+-------+------------+

?

?

?

轉(zhuǎn)載于:https://www.cnblogs.com/shangdelu/p/8478815.html

《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結(jié)

以上是生活随笔為你收集整理的MySQL-数据类型的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。