MySQL默認值(DEFAULT)和非空約束(NOT NULL)的實現(xiàn)
MySQL默認值(DEFAULT)
默認值(Default)的完整稱呼是“默認值約束(Default Constraint)”,用來指定某列的默認值。在表中插入一條新記錄時,如果沒有為某個字段賦值,系統(tǒng)就會自動為這個字段插入默認值。
例如,員工信息表中,部門位置在北京的較多,那么部門位置就可以默認為“北京”,系統(tǒng)就會自動為這個字段賦值為“北京”。
默認值約束通常用在已經(jīng)設置了非空約束的列,這樣能夠防止數(shù)據(jù)表在錄入數(shù)據(jù)時出現(xiàn)錯誤。
在創(chuàng)建表時設置默認值約束
創(chuàng)建表時可以使用 DEFAULT 關鍵字設置默認值約束,具體的語法格式如下:
<字段名> <數(shù)據(jù)類型> DEFAULT <默認值>;
其中,“默認值”為該字段設置的默認值,如果是字符類型的,要用單引號括起來。
例 1
創(chuàng)建數(shù)據(jù)表 tb_dept3,指定部門位置默認為 Beijing,SQL 語句和運行結果如下所示。
mysql> CREATE TABLE tb_dept3 -> ( -> id INT(11) PRIMARY KEY, -> name VARCHAR(22), -> location VARCHAR(50) DEFAULT 'Beijing' -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_dept3; +----------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(22) | YES | | NULL | | | location | varchar(50) | YES | | Beijing | | +----------+-------------+------+-----+---------+-------+ 3 rows in set (0.06 sec)
以上語句執(zhí)行成功之后,表 tb_dept3 上的字段 location 擁有了一個默認值 Beijing,新插入的記錄如果沒有指定部門位置,則默認都為 Beijing。
注意:在創(chuàng)建表時為列添加默認值,可以一次為多個列添加默認值,需要注意不同列的數(shù)據(jù)類型。
在修改表時添加默認值約束
修改表時添加默認值約束的語法格式如下:
ALTER TABLE <數(shù)據(jù)表名>
CHANGE COLUMN <字段名> <數(shù)據(jù)類型> DEFAULT <默認值>;
例 2
修改數(shù)據(jù)表 tb_dept3,將部門位置的默認值修改為 Shanghai,SQL 語句和運行結果如下所示。
mysql> ALTER TABLE tb_dept3 -> CHANGE COLUMN location -> location VARCHAR(50) DEFAULT 'Shanghai'; Query OK, 0 rows affected (0.15 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC tb_dept3; +----------+-------------+------+-----+----------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+----------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(22) | YES | | NULL | | | location | varchar(50) | YES | | Shanghai | | +----------+-------------+------+-----+----------+-------+ 3 rows in set (0.00 sec)
刪除默認值約束
當一個表中的列不需要設置默認值時,就需要從表中將其刪除。
修改表時刪除默認值約束的語法格式如下:
ALTER TABLE <數(shù)據(jù)表名> CHANGE COLUMN <字段名> <字段名> <數(shù)據(jù)類型> DEFAULT NULL;
例 3
修改數(shù)據(jù)表 tb_dept3,將部門位置的默認值約束刪除,SQL 語句和運行結果如下所示。
mysql> ALTER TABLE tb_dept3 -> CHANGE COLUMN location -> location VARCHAR(50) DEFAULT NULL; Query OK, 0 rows affected (0.15 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC tb_dept3; +----------+-------------+------+-----+----------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+----------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(22) | YES | | NULL | | | location | varchar(50) | YES | | NULL | | +----------+-------------+------+-----+----------+-------+ 3 rows in set (0.00 sec)
MySQL非空約束(NOT NULL)
MySQL 非空約束(NOT NULL)指字段的值不能為空。對于使用了非空約束的字段,如果用戶在添加數(shù)據(jù)時沒有指定值,數(shù)據(jù)庫系統(tǒng)就會報錯??梢酝ㄟ^ CREATE TABLE 或 ALTER TABLE 語句實現(xiàn)。在表中某個列的定義后加上關鍵字 NOT NULL 作為限定詞,來約束該列的取值不能為空。
比如,在用戶信息表中,如果不添加用戶名,那么這條用戶信息就是無效的,這時就可以為用戶名字段設置非空約束。
在創(chuàng)建表時設置非空約束
創(chuàng)建表時可以使用 NOT NULL 關鍵字設置非空約束,具體的語法格式如下:
<字段名> <數(shù)據(jù)類型> NOT NULL;
例 1
創(chuàng)建數(shù)據(jù)表 tb_dept4,指定部門名稱不能為空,SQL 語句和運行結果如下所示。
mysql> CREATE TABLE tb_dept4 -> ( -> id INT(11) PRIMARY KEY, -> name VARCHAR(22) NOT NULL, -> location VARCHAR(50) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_dept3; +----------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(22) | NO | | NULL | | | location | varchar(50) | YES | | NULL | | +----------+-------------+------+-----+---------+-------+ 3 rows in set (0.06 sec)
在修改表時添加非空約束
如果在創(chuàng)建表時忘記了為字段設置非空約束,也可以通過修改表進行非空約束的添加。
修改表時設置非空約束的語法格式如下:
ALTER TABLE <數(shù)據(jù)表名> CHANGE COLUMN <字段名> <字段名> <數(shù)據(jù)類型> NOT NULL;
例 2
修改數(shù)據(jù)表 tb_dept4,指定部門位置不能為空,SQL 語句和運行結果如下所示。
mysql> ALTER TABLE tb_dept4 -> CHANGE COLUMN location -> location VARCHAR(50) NOT NULL; Query OK, 0 rows affected (0.15 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC tb_dept4; +----------+-------------+------+-----+----------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+----------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(22) | NO | | NULL | | | location | varchar(50) | NO | | NULL | | +----------+-------------+------+-----+----------+-------+ 3 rows in set (0.00 sec)
刪除非空約束
修改表時刪除非空約束的語法規(guī)則如下:
ALTER TABLE <數(shù)據(jù)表名> CHANGE COLUMN <字段名> <字段名> <數(shù)據(jù)類型> NULL;
例 3
修改數(shù)據(jù)表 tb_dept4,將部門位置的非空約束刪除,SQL 語句和運行結果如下所示。
mysql> ALTER TABLE tb_dept4 -> CHANGE COLUMN location -> location VARCHAR(50) NULL; Query OK, 0 rows affected (0.15 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC tb_dept4; +----------+-------------+------+-----+----------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+----------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(22) | NO | | NULL | | | location | varchar(50) | YES | | NULL | | +----------+-------------+------+-----+----------+-------+ 3 rows in set (0.00 sec)
到此這篇關于MySQL默認值(DEFAULT)和非空約束(NOT NULL)的實現(xiàn)的文章就介紹到這了,更多相關MySQL默認值和非空約束內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MySQL從一個表中查出數(shù)據(jù)并插入到另一個表的詳細處理方案
這篇文章主要給大家介紹了關于MySQL從一個表中查出數(shù)據(jù)并插入到另一個表的詳細處理方案,文中通過圖文介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考借鑒價值,需要的朋友可以參考下2023-12-12多次執(zhí)行mysql_fetch_array()的指針歸位問題探討
多次執(zhí)行mysql_fetch_array(),在第二次執(zhí)行的時候,如果不加處理,就不會輸出任何內容,這種情況下只需要對循環(huán)指針進行復位即可,感興趣的朋友可以了解下啊,或許對你有所幫助2013-01-01MySQL系列之十 MySQL事務隔離實現(xiàn)并發(fā)控制
今天的內容就和大家聊一聊MySQL數(shù)據(jù)庫中關于MySQL事務隔離實現(xiàn)并發(fā)控制的問題,主要是基于鎖實現(xiàn)控制技術2021-07-07MYSQL使用inner join 進行 查詢/刪除/修改示例
本文為大家介紹下使用inner join 進行查詢/刪除/修改,具體實現(xiàn)如下,學習mysql的朋也可以學習下,希望對大家有所幫助2013-07-07登錄mysql報錯Can‘t connect to MySQL server&n
這篇文章主要給大家介紹了登錄mysql報錯 Can‘t connect to MySQL server on ‘localhost:3306‘ (10061)解決方法,文中有詳細的解決步驟,需要的朋友可以參考下2023-09-09