欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
創(chuàng )建和使用約束
約束(Constraint)是Microsoft SQL Server 提供的自動(dòng)保持數據庫完整性的一種方法,定義了可輸入表或表的單個(gè)列中的數據的限制條件(有關(guān)數據完整性的介紹請參見(jiàn)第9 章)。在SQL Server 中有5 種約束:主關(guān)鍵字約束(Primary Key Constraint)、外關(guān)鍵字約束(Foreign Key Constraint)、惟一性約束(Unique Constraint)、檢查約束(Check Constraint)和缺省約束(Default Constraint)。
7.2.1 主關(guān)鍵字約束
主關(guān)鍵字約束指定表的一列或幾列的組合的值在表中具有惟一性,即能惟一地指定一行記錄。每個(gè)表中只能有一列被指定為主關(guān)鍵字,且IMAGE 和TEXT 類(lèi)型的列不能被指定為主關(guān)鍵字,也不允許指定主關(guān)鍵字列有NULL 屬性。
定義主關(guān)鍵字約束的語(yǔ)法如下:
CONSTRAINT constraint_name
PRIMARY KEY [CLUSTERED | NONCLUSTERED]
(column_name1[, column_name2,…,column_name16])
各參數說(shuō)明如下:
constraint_name
指定約束的名稱(chēng)約束的名稱(chēng)。在數據庫中應是惟一的。如果不指定,則系統會(huì )自動(dòng)生成一個(gè)約束名。
CLUSTERED | NONCLUSTERED
指定索引類(lèi)別,CLUSTERED 為缺省值。其具體信息請參見(jiàn)下一章。
column_name
指定組成主關(guān)鍵字的列名。主關(guān)鍵字最多由16 個(gè)列組成。
例7-3: 創(chuàng )建一個(gè)產(chǎn)品信息表,以產(chǎn)品編號和名稱(chēng)為主關(guān)鍵字
create table products (
p_id char(8) not null,
p_name char(10) not null ,
price money default 0.01 ,
quantity smallint null ,
constraint pk_p_id primary key (p_id, p_name)
) on [primary]
7.2.2 外關(guān)鍵字約束
外關(guān)鍵字約束定義了表之間的關(guān)系。當一個(gè)表中的一個(gè)列或多個(gè)列的組合和其它表中的主關(guān)鍵字定義相同時(shí),就可以將這些列或列的組合定義為外關(guān)鍵字,并設定它適合哪個(gè)表中哪些列相關(guān)聯(lián)。這樣,當在定義主關(guān)鍵字約束的表中更新列值,時(shí)其它表中有與之相關(guān)聯(lián)的外關(guān)鍵字約束的表中的外關(guān)鍵字列也將被相應地做相同的更新。外關(guān)鍵字約束的作用還體現在,當向含有外關(guān)鍵字的表插入數據時(shí),如果與之相關(guān)聯(lián)的表的列中無(wú)與插入的外關(guān)鍵字列值相同的值時(shí),系統會(huì )拒絕插入數據。與主關(guān)鍵字相同,不能使用一個(gè)定義為 TEXT 或IMAGE 數據類(lèi)型的列創(chuàng )建外關(guān)鍵字。外關(guān)鍵字最多由16 個(gè)列組成。
定義外關(guān)鍵字約束的語(yǔ)法如下:
CONSTRAINT constraint_name
FOREIGN KEY (column_name1[, column_name2,…,column_name16])
REFERENCES ref_table [ (ref_column1[,ref_column2,…, ref_column16] )]
[ ON DELETE { CASCADE | NO ACTION } ]
[ ON UPDATE { CASCADE | NO ACTION } ] ]
[ NOT FOR REPLICATION ]
各參數說(shuō)明如下:
REFERENCES
指定要建立關(guān)聯(lián)的表的信息。
ref_table
指定要建立關(guān)聯(lián)的表的名稱(chēng)。
ref_column
指定要建立關(guān)聯(lián)的表中的相關(guān)列的名稱(chēng)。
ON DELETE {CASCADE | NO ACTION}
指定在刪除表中數據時(shí),對關(guān)聯(lián)表所做的相關(guān)操作。在子表中有數據行與父表中的對應數據行相關(guān)聯(lián)的情況下,如果指定了值CASCADE,則在刪除父表數據行時(shí)會(huì )將子表中對應的數據行刪除;如果指定的是NO ACTION,則SQL Server 會(huì )產(chǎn)生一個(gè)錯誤,并將父表中的刪除操作回滾。NO ACTION 是缺省值。
ON UPDATE {CASCADE | NO ACTION}
指定在更新表中數據時(shí),對關(guān)聯(lián)表所做的相關(guān)操作。在子表中有數據行與父表中的對應數據行相關(guān)聯(lián)的情況下,如果指定了值CASCADE,則在更新父表數據行時(shí)會(huì )將子表中對應的數據行更新;如果指定的是NO ACTION,則SQL Server 會(huì )產(chǎn)生一個(gè)錯誤,并將父表中的更新操作回滾。NO ACTION 是缺省值。
NOT FOR REPLICATION
指定列的外關(guān)鍵字約束在把從其它表中復制的數據插入到表中時(shí)不發(fā)生作用。
例7-4:創(chuàng )建一個(gè)訂貨表,與前面創(chuàng )建的產(chǎn)品表相關(guān)聯(lián)
create table orders(
order_id char(8),
p_id char(8),
p_name char(10) ,
constraint pk_order_id primary key (order_id) ,
foreign key(p_id, p_name) references products(p_id, p_name)
) on [primary]
注意:臨時(shí)表不能指定外關(guān)鍵字約束。
7.2.3 惟一性約束
惟一性約束指定一個(gè)或多個(gè)列的組合的值具有惟一性,以防止在列中輸入重復的值。惟一性約束指定的列可以有NULL 屬性。由于主關(guān)鍵字值是具有惟一性的,因此主關(guān)鍵字列不能再設定惟一性約束。惟一性約束最多由16 個(gè)列組成。
定義惟一性約束的語(yǔ)法如下:
CONSTRAINT constraint_name
UNIQUE [CLUSTERED | NONCLUSTERED]
(column_name1[, column_name2,…,column_name16])
例7-5:定義一個(gè)員工信息表,其中員工的身份證號具有惟一性。
create table employees (
emp_id char(8),
emp_name char(10) ,
emp_cardid char(18),
constraint pk_emp_id primary key (emp_id),
constraint uk_emp_cardid unique (emp_cardid)
) on [primary]
7.2.4 檢查約束
檢查約束對輸入列或整個(gè)表中的值設置檢查條件,以限制輸入值,保證數據庫的數據完整性??梢詫γ總€(gè)列設置符合檢查。
定義檢查約束的語(yǔ)法如下:
CONSTRAINT constraint_name
CHECK [NOT FOR REPLICATION]
(logical_expression)
各參數說(shuō)明如下:
NOT FOR REPLICATION
指定檢查約束在把從其它表中復制的數據插入到表中時(shí)不發(fā)生作用。
logical_expression
指定邏輯條件表達式返回值為T(mén)RUE 或FALSE。
例7-6: 創(chuàng )建一個(gè)訂貨表其中定貨量必須不小于10。
create table orders(
order_id char(8),
p_id char(8),
p_name char(10) ,
quantity smallint,
constraint pk_order_id primary key (order_id),
constraint chk_quantity check (quantity>=10) ,
) on [primary]
注意:對計算列不能作除檢查約束外的任何約束。
7.2.5 缺省約束
缺省約束通過(guò)定義列的缺省值或使用數據庫的缺省值對象綁定表的列,來(lái)指定列的缺省值。SQL Server 推薦使用缺省約束,而不使用定義缺省值的方式來(lái)指定列的缺省值。有關(guān)綁定缺省約束的方法請參見(jiàn)“數據完整性”章節。
定義缺省約束的語(yǔ)法如下:
CONSTRAINT constraint_name
DEFAULT constant_expression [FOR column_name]
例7-7:
constraint de_order_quantity default 100 for order_quantity
注意:不能在創(chuàng )建表時(shí)定義缺省約束,只能向已經(jīng)創(chuàng )建好的表中添加缺省約束。
7.2.6 列約束和表約束
對于數據庫來(lái)說(shuō),約束又分為列約束(Column Constraint)和表約束(Table Constraint)。
列約束作為列定義的一部分只作用于此列本身。表約束作為表定義的一部分,可以作用于
多個(gè)列。
下面舉例說(shuō)明列約束與表約束的區別。
例7-8:
create table products (
p_id char(8) ,
p_name char(10) ,
price money default 0.01 ,
quantity smallint check (quantity>=10) , /* 列約束 */
constraint pk_p_id primary key (p_id, p_name) /* 表約束 */
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
SQL Server缺省約束 列約束和表約束
關(guān)系模型的三類(lèi)完整性約束
約束之二-Constraint的簡(jiǎn)單操作
oracle數據庫的5種約束類(lèi)型
第6章數據庫對象的創(chuàng )建與管理
數據庫SQL---數據庫、基本表、視圖、索引的定義、修改、刪除
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久