佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > SQL 研究 相似的數(shù)據(jù)類型

SQL 研究 相似的數(shù)據(jù)類型

熱門標簽:AI電銷 服務外包 Linux服務器 鐵路電話系統(tǒng) 呼叫中心市場需求 地方門戶網站 網站排名優(yōu)化 百度競價排名

最常用的數(shù)值類型是int,但是它未必是最佳選擇。bigint,smallint,tinyint可以應用在特殊場合。他們的特性如下表所示:

Data type Range Storage

bigint

-2^63 (-9,223,372,036,854,775,808) to 2^63-1 (9,223,372,036,854,775,807)

8 Bytes

int

-2^31 (-2,147,483,648) to 2^31-1 (2,147,483,647)

4 Bytes

smallint

-2^15 (-32,768) to 2^15-1 (32,767)

2 Bytes

tinyint

0 to 255

1 Byte

可見如果某一列的值只有10來個值,而你卻用了int,那么沒行數(shù)據(jù)多占用了3個字節(jié)。如果有1G的行數(shù),那么你多用了3G的空間。如果它還在index中,ok,它又占用了不必要的3G。

與此類似的是Float和Real,他們的格式如下:

Data type Range Storage

float

- 1.79E+308 to -2.23E-308, 0 and 2.23E-308 to 1.79E+308

Depends on the value of n

1,24=4 bytes

25,53=8bytes

real

- 3.40E + 38 to -1.18E - 38, 0 and 1.18E - 38 to 3.40E + 38

4 Bytes

需要說明的是,float的長度取決于一個參數(shù),雖然我們通常聲明的時候并不指定float的長度,實際上是存在這樣的選項的。這個長度默認是53,數(shù)值范圍如上表所示。

顯然如果你要表示的數(shù)字不會超過10的38次方的話,你應該用real,他可以為你節(jié)省4個字節(jié)。

另一個相關的例子是decimal和numerical,他們是另一組精確表示數(shù)值的類型。float和real是不精確的,所以不能做相等的比較。

decimal和float在功能是等價的,為什么要分成兩個名字,我也不清楚。

decimal的聲明如下:decimal(p,s),p表示總共多少位,包括小數(shù)點前后的數(shù)字,s表示小數(shù)點后多少位,p不能超過38,當然s不能超過p,缺省是0。

decimal的范圍是正負10的p-s次方的結果 減去10的-s次方。比如decimal(2,1)的范圍是正負9.9。

decimal的長度和p的大小相關,如下表所示:

Precision Storage bytes

1 - 9

5

10-19

9

20-28

13

29-38

17

可使用變長字節(jié)來存放decimal。此時數(shù)據(jù)庫根據(jù)實際數(shù)值的大小來存放decimal,而不是根據(jù)聲明來判斷。如果表中沒有var length的列,那么需要額外的兩個字節(jié),否則不會有額外的需要。

可以通過如下的命令啟動一個數(shù)據(jù)庫上的變長decimal存儲:

EXEC sp_db_vardecimal_storage_format 'AdventureWorks', 'ON' ;

通過EXEC sp_db_vardecimal_storage_format ;查看所有啟動了這一功能的數(shù)據(jù)庫。

通過EXEC sp_tableoption 'Sales.SalesOrderDetail', 'vardecimal storage format', 1 ;

啟動對某個表的變長decimal存儲。

最后再看看datetime和smalldatetime,兩者都表示時間,區(qū)別如下:

datetime表達的時間更久,1753到9999,精度更高,300分之一秒,占用8個字節(jié);

smalldatetime表達的時間較短,1900到2079,精確到分,4個字節(jié)。

通常情況下,smalldatetime是夠用的。

標簽:崇左 仙桃 黃山 蘭州 衡水 湖南 湘潭 銅川

巨人網絡通訊聲明:本文標題《SQL 研究 相似的數(shù)據(jù)類型》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    广丰县| 迁安市| 嫩江县| 贵溪市| 五常市| 大化| 通渭县| 罗田县| 潞城市| 永安市| 基隆市| 来安县| 福泉市| 津南区| 安义县| 井研县| 汉阴县| 交城县| 冀州市| 张北县| 唐山市| 拉萨市| 柳州市| 舞阳县| 奉化市| 井陉县| 蒙山县| 泰和县| 丽水市| 博客| 上思县| 全南县| 德令哈市| 四川省| 虹口区| 施甸县| 山阴县| 宜兴市| 桃江县| 绵阳市| 略阳县|