sql server - 基礎數據類型說明
數據類型
- String 類型:
| 數據類型 | 描述 | 存儲 |
| char(n) | 固定長度的字符串。最多 8,000 個字符。 | Defined width |
| varchar(n) | 可變長度的字符串。最多 8,000 個字符。 | 2 bytes + number of chars |
| varchar(MAX) | 可變長度的字符串。最多 1,073,741,824 個字符。 | 2 bytes + number of chars |
| text | 可變長度的字符串。最多 2GB 文本數據。 | 4 bytes + number of chars |
| nchar(n) | 固定長度的 Unicode 字符串。最多 4,000 個字符。 | Defined width x 2 |
| ncarchar(n) | 可變長度的 Unicode 字符串。最多 4,000 個字符。 | |
| nvarchar(MAX) | 可變長度的 Unicode 字符串。最多 536,870,912 個字符。 | |
| ntext | 可變長度的 Unicode 字符串。最多 2GB 文本數據。 | |
| bit | 允許 0、1 或 NULL | 1 True / 0 False |
| binary(n) | 固定長度的二進制字符串。最多 8,000 字節。 | |
| varbinary(n) | 可變長度的二進制字符串。最多 8,000 字節。 | |
| varbinary(MAX) | 可變長度的二進制字符串。最多 2GB。 | |
| image | 可變長度的二進制字符串。最多 2GB。 |
- Number 類型:
| 數據類型 | 描述 | 存儲 |
| tinyint | 允許從 0 到 255 的所有數字。 | 1 字節 |
| smallint | 允許介于 -32,768 與 32,767 的所有數字。 | 2 字節 |
| int | 允許介于 -2,147,483,648 與 2,147,483,647 的所有數字。 | 4 字節 |
| bigint | 允許介于 -9,223,372,036,854,775,808 與 9,223,372,036,854,775,807 之間的所有數字。 | 8 字節 |
| decimal(p,s) | 固定精度和比例的數字。
允許從 -10^38 +1 到 10^38 -1 之間的數字。 p 參數指示可以存儲的最大位數(小數點左側和右側)。p 必須是 1 到 38 之間的值。默認是 18。 s 參數指示小數點右側存儲的最大位數。s 必須是 0 到 p 之間的值。默認是 0。 |
5-17 字節 |
| numeric(p,s) | 固定精度和比例的數字。
允許從 -10^38 +1 到 10^38 -1 之間的數字。 p 參數指示可以存儲的最大位數(小數點左側和右側)。p 必須是 1 到 38 之間的值。默認是 18。 s 參數指示小數點右側存儲的最大位數。s 必須是 0 到 p 之間的值。默認是 0。 |
5-17 字節 |
| smallmoney | 介于 -214,748.3648 與 214,748.3647 之間的貨幣數據。 | 4 字節 |
| money | 介于 -922,337,203,685,477.5808 與 922,337,203,685,477.5807 之間的貨幣數據。 | 8 字節 |
| float | 從 -1.79E + 308 到 1.79E + 308 的浮動精度數字數據。
n 參數指示該字段保存 4 字節還是 8 字節。float(24) 保存 4 字節,而 float(53) 保存 8 字節。n 的默認值是 53。 |
4 或 8 字節 |
| real | 從 -3.40E + 38 到 3.40E + 38 的浮動精度數字數據。 | 4 字節 |
- Date 類型:
| 數據類型 | 描述 | 存儲 |
| datetime | 從 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度為 3.33 毫秒。 | 8 字節 |
| datetime2 | 從 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度為 100 納秒。 | 6-8 字節 |
| smalldatetime | 從 1900 年 1 月 1 日 到 2079 年 6 月 6 日,精度為 1 分鐘。 | 4 字節 |
| date | 僅存儲日期。從 0001 年 1 月 1 日 到 9999 年 12 月 31 日。 | 3 bytes |
| time | 僅存儲時間。精度為 100 納秒。 | 3-5 字節 |
| datetimeoffset | 與 datetime2 相同,外加時區偏移。 | 8-10 字節 |
| timestamp | 存儲唯一的數字,每當創建或修改某行時,該數字會更新。timestamp 值基于內部時鐘,不對應真實時間。每個表只能有一個 timestamp 變量。 |
- 其他數據類型:
| 數據類型 | 描述 | 存儲 |
| sql_variant | 存儲最多 8,000 字節不同數據類型的數據,除了 text、ntext 以及 timestamp。 | |
| uniqueidentifier | 存儲全局唯一標識符 (GUID)。 | |
| xml | 存儲 XML 格式化數據。最多 2GB。 |
表設計 及 數據樣例





基礎補充
- sql server中字符串和Unicode字符串型【頭字母+n類型】的區別
varchar和nvarchar都能存儲漢字,區別在于:一個漢字占varchar(2),只占nvarchar(1),而字母只占varchar(1),那么在數據庫字段求長度的時候,用varchar就不一定知道它確切有幾個字符,如果用nvarchar,漢字也是nvarchar(1),字母也是nvarchar(1),那么很容易知道字段的長度了。
同樣的,char和nchar也一樣道理。
- 關于長度超過4000的Unicode字符串或超過8000的ASCII字符串:
不推薦使用ntext或text,應使用nvarchar(max)和varchar(max)替代text;
新建表時的錯誤提示
其中一種varchar:“長度”設置值必須介于1和8000之間。

浙公網安備 33010602011771號