1. 程式人生 > >非空約束

非空約束

如果 mys sql語句 -o number rac insert語句 oracl 剛才

在定義數據表的時候,默認情況下所有字段都是允許為空值的,如果需要禁止字段為空,那麽就需要在創建表的時候顯示指定。指定一個字段為空的方式就是在字段定義後增加NOT NULL,比如下面的SQL語句創建了表T_Person,並且設置FNumber 字段不允許為空:


MYSQL,MSSQLServer,DB2:

CREATE TABLE T_Person (FNumber VARCHAR(20) NOT NULL ,FName VARCHAR(20),FAge INT)

Oracle:

CREATE TABLE T_Person (FNumber VARCHAR2(20) NOT NULL ,FName VARCHAR2(20),FAge NUMBER (10))

創建T_Person表後我們執行下面的SQL語句進行測試:


INSERT INTO T_Person (FNumber, FName, FAge) VALUES ( NULL , "kingchou", 20)

因為在定義T_Person 表的時候設定字段FNumber 不能為空,而這個SQL 語句中將FNumber 字段設置為NULL,所以在數據庫中執行此SQL 語句後數據庫會報出下面錯誤信息:

  • 不能將值NULL 插入列"FNumber",表 "demo.dbo.T_Person";列不允許有空值。INSERT 失敗。而下面的SQL語句則可以正確的執行:

INSERT INTO T_Person (FNumber, FName, FAge) VALUES ( "1" , "kingchou", 20)

非空約束不僅對通過INSERT語句插入的數據起作用,而且對於使用UPDATE語句進行更新時也起作用。執行下面的SQL語句嘗試將剛才插入的那條數據的FNumber 字段更新為NULL:


UPDATE T_Person SET FNumber = NULL

在數據庫中執行此SQL語句後數據庫會報出下面錯誤信息:

  • 不能將值NULL 插入列"FNumber",表 "demo.dbo.T_Person";列不允許有空值。UPDATE 失敗。

非空約束