非空約束
阿新 • • 發佈:2018-10-21
如果 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 失敗。
非空約束