unsigned

unsigned

整型的每一種都分為:無符號(unsigned)和有符號(signed)兩種類型(float和double總是帶符號的),在除char以外的數據類型中,默認情況下聲明的整型變數都是有符號的類型;char在默認情況下總是無符號的。在除char以外的數據類型中,如果需聲明無符號類型的話就需要在類型前加上unsigned。無符號版本和有符號版本的區別就是無符號類型能保存2倍於有符號類型的正整數數據,比如16位系統中一個short能存儲的數據的範圍為-32768~32767,而unsigned能存儲的數據範圍則是0~65535。由於在計算機中,整數是以補碼形式存放的。根據最高位的不同,如果是1,有符號數的話就是負數;如果是無符號數,則都解釋為正數。另外,unsigned若省略後一個關鍵字,大多數編譯器都會認為是unsigned int。

基本介紹

整型的每一種都有無符號( unsigned)和有符號( signed)兩種類型,在默認情況下聲明的整型變數都是有符號的類型( char有點特別),如果需聲明無符號類型的話就需要在類型前加上 unsigned。無符號版本和有符號版本的區別就是有符號類型需要使用一個bit來表示數字的正負,比如16位系統中一個int能存儲的數據的範圍為–32768 ~ 32767(16位2進制的最高位作為符號位‘1’為負‘0’為正),而 unsigned能存儲的數據範圍則是0~65535(這個最高位不用做符號位,所以是2的16次方,一共65536)。由於在計算機中,整數是以補碼形式存放的。根據最高位的不同,如果是1,有符號數的話就是負數;如果是無符號數,則都解釋為正數。同時在相同位數的情況下,所能表達的整數範圍變大。另外, unsigned若省略後一個關鍵字,大多數編譯器都會認為是 unsigned int

舉例

在sql語句中的意義

sql語句中,創建一個數據表時

ceate table user{user_id int unsigned}

當中的unsigned表示,數據項user_id恆為正整數。

例如如果tinyint最大是127,那tinyintunsigned最大就可以到 127 * 2
unsigned 屬性只針對整型,而binary屬性只用於char 和varchar。

類型 說明
tinyint 非常小的整數
smallint 較小整數
mediumint 中等大小整數
int 標準整數
bigint 較大整數
float 單精度浮點數
double 雙精度浮點數
decimal 一個串的浮點數

每種數值類型的名稱和取值範圍如下表所示

類型說明 取值範圍
tinyint[(m)] 有符號值:-128 到127(- 2 到2 - 1) 無符號值:0到255(0 到2- 1)1個位元組
smallint[(m)] 有符號值:-32768 到32767(- 2 到2 - 1) 無符號值:0到65535(0 到2 - 1)2個位元組
mediumint[(m)] 有符號值:-8388608 到8388607(- 2 到2 - 1 ) 無符號值:0到16777215(0 到22 4 - 1)3個位元組
int[(m)] 有符號值:-2147683648 到2147683647(- 2 到2- 1) 無符號值:0到4294967295(0 到2 - 1)4個位元組
bigint[(m)] 有符號值:-9223372036854775808 到9223373036854775807(- 2到2-1) 無符號值:0到18446744073709551615(0到2 – 1) 8個位元組
float[(m, d)] 最小非零值:±1.175494351e - 38
double[(m,d)] 最小非零值:±2.2250738585072014e - 308
decimal (m, d) 可變;其值的範圍依賴於m 和d

相關詞條

相關搜尋

熱門詞條

聯絡我們