1. 程式人生 > >測試人員必知必會的SQL知識04

測試人員必知必會的SQL知識04

今天我們介紹建立表的相關指令,在具體介紹指令之前,還是要現講一些概念。

前面我們說了,列有列名稱和列型別兩個屬性,我們就來新看一下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
)