語法表格 1.在SQL Server 2000,說明主鍵約束和唯一約束的區(qū)別?2.對學(xué)生信息表來說,能否將姓名字段設(shè)置為主鍵,為什么?3.舉例說明在什么情況下需要唯一約束?
1.在SQL Server 2000,說明主鍵約束和唯一約束的區(qū)別?2.對學(xué)生信息表來說,能否將姓名字段設(shè)置為主鍵,為什么?3.舉例說明在什么情況下需要唯一約束?1. 主鍵約束:有一列或列的組合,其值
1.在SQL Server 2000,說明主鍵約束和唯一約束的區(qū)別?2.對學(xué)生信息表來說,能否將姓名字段設(shè)置為主鍵,為什么?3.舉例說明在什么情況下需要唯一約束?
1. 主鍵約束:有一列或列的組合,其值可以唯一地標(biāo)識表中的每一行。
唯一約束:不允許數(shù)據(jù)庫表在指定列上具有相同的值,但允許空值。
區(qū)別:一個表可以定義多個唯一約束,但只能定義一個主鍵約束;空列可以定義唯一約束,但不能定義主鍵約束。
2. 否,因為名稱字段可能重復(fù),并且主鍵約束不允許重復(fù)字段,所以您應(yīng)該將非重復(fù)字段設(shè)置為主鍵。
3。如果表中有主鍵,還希望某些列數(shù)據(jù)不重復(fù),或者不希望插入或修改的數(shù)據(jù)與原始數(shù)據(jù)相同,請使用unique約束。
ORA-00001: 違反唯一約束條件?
反唯一約束是重復(fù)主鍵。解決方案如下:
1。非空約束可以在創(chuàng)建表時創(chuàng)建,也可以在創(chuàng)建表后創(chuàng)建。如下圖所示。
2. 查詢數(shù)據(jù)字典中新建立的非空約束。
3. 唯一約束用于確保字段或字段組合中沒有重復(fù)的值。
4. 類似地,可以在創(chuàng)建表期間或之后創(chuàng)建unique約束。
5. 最后,查詢數(shù)據(jù)字典中的唯一約束。