您好,登錄后才能下訂單哦!
mysql中給字段設置默認值的方法?這個問題可能是我們日常學習或工作經常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家帶來的參考內容,讓我們一起來看看吧!
方法:1、創建表時用“CREATE TABLE 表名(字段名 數據類型 DEFAULT 默認值;)”語句設置;2、修改表時用“ALTER TABLE 表名 CHANGE COLUMN 字段名 數據類型 DEFAULT 默認值;“語句設置。
默認值(Default)的完整稱呼是“默認值約束(Default Constraint)”,用來指定某字段的默認值。在表中插入一條新記錄時,如果沒有為某個字段賦值,系統就會自動為這個字段插入默認值。
在創建表時設置默認值約束
創建表時可以使用 DEFAULT 關鍵字設置默認值約束,具體的語法格式如下:
<字段名> <數據類型> DEFAULT <默認值>;
其中,“默認值”為該字段設置的默認值,如果是字符類型的,要用單引號括起來。
例 1
創建數據表 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)
以上語句執行成功之后,表 tb_dept3 上的字段 location 擁有了一個默認值 Beijing,新插入的記錄如果沒有指定部門位置,則默認都為 Beijing。
注意:在創建表時為列添加默認值,可以一次為多個列添加默認值,需要注意不同列的數據類型。
在修改表時添加默認值約束
修改表時添加默認值約束的語法格式如下:
ALTER TABLE <數據表名> CHANGE COLUMN <字段名> <數據類型> DEFAULT <默認值>;
例 2
修改數據表 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 <數據表名> CHANGE COLUMN <字段名> <字段名> <數據類型> DEFAULT NULL;
例 3
修改數據表 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中給字段設置默認值的方法大概了解了嗎?希望文章內容對大家有所幫助。如果想了解更多相關文章內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。