測試人員必知必會的SQL知識04
阿新 • • 發佈:2019-01-28
今天我們介紹建立表的相關指令,在具體介紹指令之前,還是要現講一些概念。
前面我們說了,列有列名稱和列型別兩個屬性,我們就來新看一下SQL Server中的列型別。
SQL Server 資料型別
Character 字串:
資料型別 | 描述 | 儲存 |
---|---|---|
char(n) | 固定長度的字串。最多 8,000 個字元。 | n |
varchar(n) | 可變長度的字串。最多 8,000 個字元。 | |
varchar(max) | 可變長度的字串。最多 1,073,741,824 個字元。 | |
text | 可變長度的字串。最多 2GB 字元資料。 |
Unicode 字串:
資料型別 | 描述 | 儲存 |
---|---|---|
nchar(n) | 固定長度的 Unicode 資料。最多 4,000 個字元。 | |
nvarchar(n) | 可變長度的 Unicode 資料。最多 4,000 個字元。 | |
nvarchar(max) | 可變長度的 Unicode 資料。最多 536,870,912 個字元。 | |
ntext | 可變長度的 Unicode 資料。最多 2GB 字元資料。 |
Binary 型別:
資料型別 | 描述 | 儲存 |
---|---|---|
bit | 允許 0、1 或 NULL | |
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(n) | 從 -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 bytes |
datetime2 | 從 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度為 100 納秒。 | 6-8 bytes |
smalldatetime | 從 1900 年 1 月 1 日 到 2079 年 6 月 6 日,精度為 1 分鐘。 | 4 bytes |
date | 僅儲存日期。從 0001 年 1 月 1 日 到 9999 年 12 月 31 日。 | 3 bytes |
time | 僅儲存時間。精度為 100 納秒。 | 3-5 bytes |
datetimeoffset | 與 datetime2 相同,外加時區偏移。 | 8-10 bytes |
timestamp | 儲存唯一的數字,每當建立或修改某行時,該數字會更新。timestamp 基於內部時鐘,不對應真實時間。每個表只能有一個 timestamp 變數。 |
為了保證資料的完整性,我們對列還有一些約束。約束分為行約束、列約束和引用約束。行約束和列約束是針對單表的,引用約束是針對兩個表的。
行約束:索引、唯一約束、主鍵(不為空;記錄不能重複)、自動增長(針對int型別)
列約束:check約束、NOT NULL約束、Default約束
引用約束:外來鍵約束
好了,我們開始學習指令吧。
CREATE DATABASE TestDB;
USE TestDB;
--建一個最簡單的表
CREATE TABLE test01(
ID int,
Sname nvarchar(100),
grade varchar(50)
)
--空約束,NOT NULL不可以為空
CREATE TABLE Student(
ID int NOT NULL,
Sname nvarchar(50),
score real
)
-- 主鍵約束
--PRIMARY KEY 約束唯一標識資料庫表中的每條記錄。
--主鍵必須包含唯一的值。
--主鍵列不能包含 NULL 值。
--每個表應該都一個主鍵,並且每個表只能有一個主鍵。
CREATE TABLE Student01(
ID int PRIMARY KEY,
Sname nvarchar(50),
score real
)
--唯一約束,一個表中只能有一個主鍵約束,但是可以有多個約束。
--Primary Key自動擁有唯一約束
CREATE TABLE Student02(
ID int PRIMARY KEY NOT NULL,
Sname nvarchar(50) UNIQUE,
score real
)
--預設約束
CREATE TABLE Student03(
ID int PRIMARY KEY NOT NULL,
Sname nvarchar(50) UNIQUE,
score real,
address nvarchar(200) DEFAULT '釣魚島是中國的'
)
--自動增長約束
CREATE TABLE Student04(
ID int PRIMARY KEY NOT NULL IDENTITY(1001,1),
Sname nvarchar(50) UNIQUE,
score real
)