本篇文章給大家分享的是有關如何設置MySQL的字段默認值,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

我們可以用 DEFAULT 關鍵字來定義默認值,默認值通常用在非空列,這樣能夠防止數據表在錄入數據時出現錯誤。
創建表時,我們可以給某個列設置默認值,具體語法格式如下:
# 格式模板
<字段名> <數據類型> DEFAULT <默認值>
# 示例
mysql> CREATE TABLE `test_tb` (
-> `id` int NOT NULL AUTO_INCREMENT,
-> `col1` varchar(50) not null DEFAULT 'a',
-> `col2` int not null DEFAULT 1,
-> PRIMARY KEY (`id`)
-> ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.06 sec)
mysql> desc test_tb;
+-------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| col1 | varchar(50) | NO | | a | |
| col2 | int(11) | NO | | 1 | |
+-------+-------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)
mysql> insert into test_tb (col1) values ('fdg');
Query OK, 1 row affected (0.01 sec)
mysql> insert into test_tb (col2) values (2);
Query OK, 1 row affected (0.03 sec)
mysql> select * from test_tb;
+----+------+------+
| id | col1 | col2 |
+----+------+------+
| 1 | fdg | 1 |
| 2 | a | 2 |
+----+------+------+
2 rows in set (0.00 sec)通過以上實驗可以看出,當該字段設置默認值后,插入數據時,若不指定該字段的值,則以默認值處理。
關于默認值,還有其他操作,例如修改默認值,增加默認值,刪除默認值等。一起來看下這些應該如何操作。
# 添加新字段 并設置默認值 alter table `test_tb` add column `col3` varchar(20) not null DEFAULT 'abc'; # 修改原有默認值 alter table `test_tb` alter column `col3` set default '3a'; alter table `test_tb` change column `col3` `col3` varchar(20) not null DEFAULT '3b'; alter table `test_tb` MODIFY column `col3` varchar(20) not null DEFAULT '3c'; # 刪除原有默認值 alter table `test_tb` alter column `col3` drop default; # 增加默認值(和修改類似) alter table `test_tb` alter column `col3` set default '3aa';
其實不止非空字段可以設置默認值,普通字段也可以設置默認值,不過一般推薦字段設為非空。
mysql> alter table `test_tb` add column `col4` varchar(20) DEFAULT '4a'; Query OK, 0 rows affected (0.12 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> desc test_tb; +-------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | col1 | varchar(50) | NO | | a | | | col2 | int(11) | NO | | 1 | | | col3 | varchar(20) | NO | | 3aa | | | col4 | varchar(20) | YES | | 4a | | +-------+-------------+------+-----+---------+----------------+ 5 rows in set (0.00 sec)
在項目開發中,有些默認值字段還是經常使用的,比如默認為當前時間、默認未刪除、某狀態值默認為 1 等等。簡單通過下表展示下常用的一些默認值字段。
CREATE TABLE `default_tb` ( `id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '自增主鍵', ... `country` varchar(50) not null DEFAULT '中國', `col_status` tinyint not null DEFAULT 1 COMMENT '1:代表啥 2:代表啥...', `col_time` datetime NOT NULL DEFAULT '2020-10-01 00:00:00' COMMENT '什么時間', `is_deleted` tinyint not null DEFAULT 0 COMMENT '0:未刪除 1:刪除', `create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創建時間', `update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改時間', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
這里也要提醒下,默認值一定要和字段類型匹配,比如說某個字段表示狀態值,可能取值 1、2、3... 那這個字段推薦使用 tinyint 類型,而不應該使用 char 或 varchar 類型。
筆者結合個人經驗,總結下關于默認值使用的幾點建議:
非空字段設置默認值可以預防插入報錯。
默認值同樣可設置在可為 null 字段。
一些狀態值字段好給出備注,標明某個數值代表什么狀態。
默認值要和字段類型匹配。
以上就是如何設置MySQL的字段默認值,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創新互聯行業資訊頻道。
文章名稱:如何設置MySQL的字段默認值-創新互聯
標題網址:http://www.yijiale78.com/article44/pgsee.html
成都網站建設公司_創新互聯,為您提供電子商務、云服務器、商城網站、App設計、網站設計、靜態網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯