亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

MySQL基礎教程4 —— 數(shù)據(jù)類型之存儲需求及如何選擇正確的類型

瀏覽:12日期:2023-10-17 16:01:16
1. 列類型存儲需求

根據(jù)類別列出了MySQL支持的每個列類型的存儲需求。

MyISAM表中行的最大大小為65,534字節(jié)。每個BLOB和TEXT列 賬戶只占其中的5至9個字節(jié)。

如果MyISAM表包括變長列類型,記錄格式也是可變長度。當創(chuàng)建表時,在某些條件下,MySQL可以將一個列從變長類型改為固定長度的類型或反之亦然。

數(shù)值類型存儲需求

列類型存儲需求TINYINT1個字節(jié)SMALLINT2個字節(jié)MEDIUMINT3個字節(jié)INT,INTEGER4個字節(jié)BIGINT8個字節(jié)FLOAT(p)如果0 <=p<= 24為4個字節(jié),如果25 <=p<= 53為8個字節(jié)FLOAT4個字節(jié)DOUBLE [PRECISION], itemREAL8個字節(jié)DECIMAL(M,D),NUMERIC(M,D)變長;參見下面的討論BIT(M)大約(M+7)/8個字節(jié)

DECIMAL(和NUMERIC)的存儲需求與具體版本有關:

使用二進制格式將9個十進制(基于10)數(shù)壓縮為4個字節(jié)來表示DECIMAL列值。每個值的整數(shù)和分數(shù)部分的存儲分別確定。每個9位數(shù)的倍數(shù)需要4個字節(jié),并且“剩余的”位需要4個字節(jié)的一部分。下表給出了超出位數(shù)的存儲需求:

剩余的字節(jié)位數(shù)數(shù)目00112132425363748494

日期和時間類型的存儲需求

列類型存儲需求DATE3個字節(jié)DATETIME8個字節(jié)TIMESTAMP4個字節(jié)TIME3個字節(jié)YEAR1個字節(jié)

字符串類型的存儲需求

列類型存儲需求CHAR(M)M個字節(jié),0<=M<=255VARCHAR(M)L+1個字節(jié),其中L<=M且0<=M<=65535(參見下面的注釋)BINARY(M)M個字節(jié),0<=M<=255VARBINARY(M)L+1個字節(jié),其中L<=M且0<=M<=255TINYBLOB,TINYTEXTL+1個字節(jié),其中L< 28BLOB,TEXTL+2個字節(jié),其中L< 216MEDIUMBLOB,MEDIUMTEXTL+3個字節(jié),其中L< 224LONGBLOB,LONGTEXTL+4個字節(jié),其中L< 232ENUM(’value1’,’value2’,...)1或2個字節(jié),取決于枚舉值的個數(shù)(最多65,535個值)SET(’value1’,’value2’,...)1、2、3、4或者8個字節(jié),取決于set成員的數(shù)目(最多64個成員)

VARCHAR、BLOB和TEXT類是變長類型。每個類型的存儲需求取決于列值的實際長度(用前面的表中的L表示),而不是該類型的最大可能的大小。例如,VARCHAR(10)列可以容納最大長度為10的字符串。實際存儲需求是字符串(L)的長度,加上一個記錄字符串長度的字節(jié)。對于字符串’abcd’,L是4,存儲需要5個字節(jié)。

對于CHAR、VARCHAR和TEXT類型,前面的表中的值L和M應解釋為字符數(shù)目,并且列定義中的這些類型的長度表示字符數(shù)目。例如,要想保存一個TINYTEXT值需要L字符+ 1個字節(jié)。

要想計算用于保存具體CHAR、VARCHAR或者TEXT列值的字節(jié)數(shù),需要考慮該列使用的字符集。在具體情況中,當使用Unicode時,必須記住所有Unicode字符使用相同的字節(jié)數(shù)。

注釋:VARCHAR列的有效最大長度為65,532字符。

NDBCLUSTER引擎只支持固定寬度的列。這說明MySQL簇中的表中的VARCHAR列的行為如同類型CHAR(不同的是每個記錄仍然有一個額外字節(jié)空間)。例如,在Cluster表中,聲明為VARCHAR(100)的列中的每個記錄存儲時將占用101個字節(jié),無論實際存儲的記錄中的字符串的長度為多少。

BLOB和TEXT類需要1、2、3或者4個字節(jié)來記錄列值的長度,取決于該類的最大可能的長度。

在NDB Cluster存儲引擎中,TEXT和BLOB列的實施是不同的,其中TEXT列中的每個記錄由兩個單獨部分組成。一個是固定大小(256字節(jié)),并且實際上保存在原表中。另一個包括超出256字節(jié)的任何數(shù)據(jù),保存在隱含的表中。第2個表中的記錄總是2,000字節(jié)長。這說明如果size<= 256,TEXT列的大小為256(其中size表示記錄的大小);否則,大小是256 +size+(2000–(size–256)%2000)。

ENUM對象的大小由不同的枚舉值的數(shù)目確定。枚舉用一個字節(jié),可以有255個可能的值。當枚舉的值位于256和65,535之間時,用兩個字節(jié)。

SET對象的大小由不同的set成員的數(shù)量確定。如果set大小是N,對象占(N+7)/8個字節(jié),四舍五入到1、2、3、4或者8個字節(jié)。SET最多可以有64個成員。

2.選擇正確的數(shù)據(jù)類型

為了優(yōu)化存儲,在任何情況下均應使用最精確的類型。例如,如果列的值的范圍為從1到99999,若使用整數(shù),則MEDIUMINT UNSIGNED是好的類型。在所有可以表示該列值的類型中,該類型使用的存儲最少。

用精度為65位十進制數(shù)(基于10)對DECIMAL列進行所有基本計算(+、-、*、/)。

使用雙精度操作對DECIMAL值進行計算。如果準確度不是太重要或如果速度為最高優(yōu)先級,DOUBLE類型即足夠了。為了達到高精度,可以轉換到保存在BIGINT中的定點類型。這樣可以用64位整數(shù)進行所有計算,根據(jù)需要將結果轉換回浮點值。

3.使用來自其他數(shù)據(jù)庫引擎的列類型

為了使用由其它賣方編寫的SQL執(zhí)行代碼,MySQL按照下表所示對列類型進行映射。通過這些映射,可以很容易地從其它數(shù)據(jù)庫引擎將表定義導入到MySQL中:

其它賣方類型MySQL類型BOOL,TINYINTBOOLEANTINYINTCHAR VARYING(M)VARCHAR(M)DECDECIMALFIXEDDECIMALFLOAT4FLOATFLOAT8DOUBLEINT1TINYINTINT2SMALLINTINT3MEDIUMINTINT4INTINT8BIGINTLONG VARBINARYMEDIUMBLOBLONG VARCHARMEDIUMTEXTLONGMEDIUMTEXTMIDDLEINTMEDIUMINTNUMERICDECIMAL

在創(chuàng)建表時對列類型進行映射,然后原來的類型定義被丟棄。如果你使用其它賣方的類型創(chuàng)建一個表,然后執(zhí)行DESCRIBEtbl_name語句,MySQL使用等效的MySQL類型來報告表的結構。例如:

mysql> CREATE TABLE t (a BOOL, b FLOAT8, c LONG, d NUMERIC);Query OK, 0 rows affected (0.08 sec)mysql> DESCRIBE t;+-------+---------------+------+-----+---------+-------+| Field | Type | Null | Key | Default | Extra |+-------+---------------+------+-----+---------+-------+| a | tinyint(1) | YES | | NULL | || b | double | YES | | NULL | || c | mediumtext | YES | | NULL | || d | decimal(10,0) | YES | | NULL | |+-------+---------------+------+-----+---------+-------+4 rows in set (0.00 sec)

相關文章:
主站蜘蛛池模板: 米奇888在线播放欧美 | 亚洲欧美日韩国产精品影院 | 美女视频很黄很a免费国产 美女视频黄.免费网址 | 国产一区二区三区不卡免费观看 | 国产亚洲欧美日韩在线观看一区二区 | 亚洲六月丁香六月婷婷蜜芽 | 亚洲一区二区三区四区五区六区 | 久久不见久久见免费影院www日本 | 国产一级真人毛爱做毛片 | 怡红院免费全部视频在线视频 | 91视频综合网 | 日本三级香港三级人妇 m | 亚洲视频在线a视频 | 亚洲一区二区免费 | 成人在线午夜 | 亚洲一级毛片欧美一级说乱 | 在线久| 日本免费一二区视频 | 国产一成人精品福利网站 | 国产在线精品一区二区 | 国产精品人成人免费国产 | 在线观看香蕉免费啪在线观看 | 亚洲欧美视频 | 亚洲精品一区二区三区在 | 日本久操 | 国产一区二区亚洲精品天堂 | 2021国产精品一区二区在线 | 亚洲专区欧美专区 | 97视频在线视频 | 亚洲人成高清毛片 | 精品国产品香蕉在线观看 | 国产亚洲精品久久 | 成年人网站在线观看免费 | 淫模| 久久国内精品 | 成人久久18免费网站游戏 | 久久久网久久久久合久久久久 | 亚洲欧洲国产成人综合一本 | 手机在线观看一级午夜片 | 精品欧美成人bd高清在线观看 | 亚洲在线观看网站 |