欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL數(shù)據(jù)庫(kù)表約束超詳細(xì)講解

 更新時(shí)間:2023年11月21日 16:41:24   作者:Bridge?Fish  
這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫(kù)表約束的相關(guān)資料,MySQL?約束是用于保持?jǐn)?shù)據(jù)完整性和一致性的規(guī)則,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

在MySQL里,“約束”指的是對(duì)表中數(shù)據(jù)的一種限制約束,它能夠確保數(shù)據(jù)庫(kù)中數(shù)據(jù)的準(zhǔn)確性和有效性

比如有的數(shù)據(jù)是必填項(xiàng),就像身份認(rèn)證的時(shí)候,或者填注冊(cè)信息的時(shí)候,手機(jī)號(hào)身份證這種就不能空著,所以就有了非空約束;又有的數(shù)據(jù)比如用戶的唯一id,不能跟其他人的一樣,所以就需要使用唯一約束等等。

在MySQL中主要有6種約束:主鍵約束、外鍵約束、唯一約束、檢查約束、非空約束和默認(rèn)值約束。

一. 主鍵約束——PRIMARY KEY

“主鍵約束“是6種約束中使用最多的約束。

在建立數(shù)據(jù)表的時(shí)候,一般情況下,為了方便更快地查找表中的記錄,都會(huì)要求在表中設(shè)置一個(gè)“主鍵”。”主鍵“是表里面的一個(gè)特殊字段,這個(gè)字段能夠唯一標(biāo)識(shí)該表中的每條信息。

主鍵分為“單字段主鍵”和“多字段聯(lián)合主鍵”,并且在使用主鍵的時(shí)候需要注意以下幾個(gè)點(diǎn):

  • 一個(gè)表只能定義一個(gè)主鍵;
  • 主鍵值必須唯一標(biāo)識(shí)表中的每一行,并且不能出現(xiàn)null的情況,即表中不能存在有相同主鍵的兩行或兩行以上數(shù)據(jù),嚴(yán)格遵守唯一性原則;
  • 一個(gè)字段名只能在聯(lián)合主鍵字段表中出現(xiàn)一次;
  • 聯(lián)合主鍵不能包含不必要的多余字段,以滿足最小化原則。

1.在建表時(shí)設(shè)置主鍵約束

設(shè)置單字段主鍵

1)在定義字段的時(shí)候設(shè)置主鍵約束,語(yǔ)法格式:

<字段名> <數(shù)據(jù)類型> PRIMARY KEY [默認(rèn)值]

例:在數(shù)據(jù)庫(kù)中創(chuàng)建學(xué)生信息數(shù)據(jù)表st_info,主鍵為st_id, SQL語(yǔ)句以及運(yùn)行結(jié)果如下:

create table st_info(
st_id int(10) primary key,
  name varchar(20),
  class varchar(10),
  gender varchar(4),
  age int(2)
);

mysql> desc st_info;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | YES |     | NULL |       |
| class | varchar(10) | YES | | NULL   | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

2)在定義完所有字段之后指定部件,語(yǔ)法格式:

[CONSTRAINT <約束名>] PRIMARY KEY [字段名]

 在數(shù)據(jù)庫(kù)中創(chuàng)建學(xué)生信息數(shù)據(jù)表st_info2,主鍵為st_id, SQL語(yǔ)句以及運(yùn)行結(jié)果如下:

create table st_info2(
st_id int(10),
  name varchar(20),
  class varchar(10),
  gender varchar(4),
  age int(2),
   primary key(st_id)
);

mysql> desc st_info2;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | YES |     | NULL |       |
| class | varchar(10) | YES | | NULL   | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

設(shè)置聯(lián)合主鍵

聯(lián)合主鍵即一張表的主鍵由多個(gè)字段組成。

比如在學(xué)生信息表中,可以設(shè)置st_id跟name來(lái)作為聯(lián)合主鍵,語(yǔ)法格式以及SQL語(yǔ)句實(shí)現(xiàn)為:

PRIMARY KEY [字段1,字段2,…,字段n]

create table st_info3(
  st_id int(10),
  name varchar(20),
  class varchar(10),
  gender varchar(4),
  age int(2),
   primary key(st_id,name)
);

mysql> desc st_info3;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO | PRI | NULL |       |
| class | varchar(10) | YES | | NULL   | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

需要注意的是,在設(shè)置聯(lián)合主鍵的時(shí)候,不能在每個(gè)字段名后面直接聲明主鍵約束。

2. 在修改表的時(shí)候添加主鍵約束

如果在創(chuàng)建表的時(shí)候沒(méi)有設(shè)置主鍵約束,還可以在修改表時(shí)進(jìn)行添加,但是設(shè)置成主鍵約束的字段不允許有空值。語(yǔ)法格式:

ALTER TABLE <數(shù)據(jù)表名> ADD PRIMARY KEY(<字段名>);

mysql> desc st_info4;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class | varchar(10) | YES | | NULL   | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+

st_idname設(shè)置成主鍵:

mysql> alter table st_info4 add primary key(st_id,name);
Query OK, 0 rows affected (0.04 sec)
Records: 0 Duplicates: 0  Warnings: 0

mysql> desc st_info4;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO | PRI | NULL |       |
| class | varchar(10) | YES | | NULL   | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

3. 刪除主鍵約束

當(dāng)一個(gè)表中不需要主鍵約束時(shí),就需要從表中將其刪除。

 刪除st_info4數(shù)據(jù)表中的主鍵約束:

mysql> alter table st_info4 drop primary key;
Query OK, 0 rows affected (0.06 sec)
Records: 0 Duplicates: 0  Warnings: 0

mysql> desc st_info4;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class | varchar(10) | YES | | NULL   | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

4. 【補(bǔ)充】 MySQL設(shè)置主鍵自增長(zhǎng) :

在MySQL里,當(dāng)主鍵定義為自增長(zhǎng)后,主鍵的值就不需要自己再輸入數(shù)據(jù)了,而是由數(shù)據(jù)庫(kù)系統(tǒng)根據(jù)定義自動(dòng)賦值,每增加一條記錄,主鍵就會(huì)自動(dòng)根據(jù)設(shè)置的步長(zhǎng)進(jìn)行增長(zhǎng)。

在MySQL中自增長(zhǎng)的關(guān)鍵字是AUTO_INCREMENT,語(yǔ)法格式為:

字段名 數(shù)據(jù)類型 AUTO_INCREMENT

 創(chuàng)建學(xué)生信息表st_info5,指定st_id字段自增,

create table st_info5(
  st_id int(10) primary key auto_increment,
    name varchar(20) not null,
    class varchar(10),
    gender varchar(4),
    age int(2)
);

此時(shí)可以不用再手動(dòng)插入st_id的數(shù)據(jù):

insert into st_info5(name,class,gender,age) 
values('王思瑤','管理學(xué)1班','女',18),
      ('王綺夢(mèng)','管理學(xué)1班','女',18),
      ('李若彤','管理學(xué)1班','男',18);
      
mysql> select * from st_info5;
+-------+--------+-----------+--------+------+
| st_id | name | class     | gender | age |
+-------+--------+-----------+--------+------+
| 1 | 王思瑤 | 管理學(xué)1班 | 女 | 18 |
| 2 | 王綺夢(mèng) | 管理學(xué)1班 | 女 | 18 |
| 3 | 李若彤 | 管理學(xué)1班 | 男 | 18 |
+-------+--------+-----------+--------+------+
3 rows in set (0.01 sec)

但是在設(shè)置學(xué)號(hào)的時(shí)候不一定是從1開始的,比如要從2000150001開始,則需要在建表之后設(shè)置自增的起始數(shù)據(jù):

create table st_info6(
    st_id int(10) primary key auto_increment,
    name varchar(20) not null,
    class varchar(10),
    gender varchar(4),
    age int(2)
)auto_increment=2000150001;

insert into st_info6(name,class,gender,age) 
values('王思瑤','管理學(xué)1班','女',18),
      ('王綺夢(mèng)','管理學(xué)1班','女',18),
      ('李若彤','管理學(xué)1班','男',18);
      
mysql> select * from st_info6;
+------------+--------+-----------+--------+------+
| st_id | name | class     | gender | age |
+------------+--------+-----------+--------+------+
| 2000150001 | 王思瑤 | 管理學(xué)1班 | 女 | 18 |
| 2000150002 | 王綺夢(mèng) | 管理學(xué)1班 | 女 | 18 |
| 2000150003 | 李若彤 | 管理學(xué)1班 | 男 | 18 |
+------------+--------+-----------+--------+------+
3 rows in set (0.00 sec)

值得注意的地方是,如果在插入某一行數(shù)據(jù)產(chǎn)生了報(bào)錯(cuò),則最終自增字段可能會(huì)出現(xiàn)不連續(xù)的情況。

二. 外鍵約束——FOREIGN KEY

外鍵約束是表的一個(gè)特殊字段,普遍會(huì)和主鍵約束一起使用,用來(lái)確保數(shù)據(jù)的一致性。

對(duì)于兩個(gè)具有關(guān)聯(lián)關(guān)系的表來(lái)說(shuō),相關(guān)聯(lián)字段中主鍵所在的表就是主表(父表),外鍵所在的表就是從表(子表)。

所以外鍵就是用來(lái)建立主表與從表的關(guān)聯(lián)關(guān)系,為兩個(gè)表的數(shù)據(jù)建立連接,約束兩個(gè)表中數(shù)據(jù)的一致性和完整性。

在定義外鍵時(shí)需要遵守以下規(guī)則:

  • 主表必須已經(jīng)存在于數(shù)據(jù)庫(kù)中,或者是當(dāng)前正在創(chuàng)建的表。如果是后一種情況,則主表與從表是同一個(gè)表,這樣的表稱做自參照表,這種結(jié)構(gòu)稱做自參照完整性;
  • 必須為主表定義主鍵;
  • 主鍵不能包含空值,但允許在外鍵中出現(xiàn)空值;
  • 在主表的表名后面指定列名或列名的組合,這個(gè)列或列的組合必須是主表的主鍵或候選鍵;
  • 外鍵中列的數(shù)目必須和主表的主鍵中列的數(shù)目相同;
  • 外鍵中列的數(shù)據(jù)類型必須和主表主鍵中對(duì)應(yīng)列的數(shù)據(jù)類型相同。

1.在創(chuàng)建表時(shí)設(shè)置外鍵約束

在建表語(yǔ)句中,可以加入關(guān)鍵字FOREIGN KEY來(lái)指定外鍵,用REFERENCES來(lái)連接與主表的關(guān)系語(yǔ)法格式:

CONSTRAINT <約束名>
FOREIGN KEY <外鍵名>(字段名1,字段名2...)
REFERENCES <主表名>(主鍵字段名)

例:

① 使用1部分創(chuàng)建的st_info5數(shù)據(jù)表作為主表:

mysql> desc st_info5;
+--------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+----------------+
| st_id | int | NO | PRI | NULL | auto_increment |
| name | varchar(20) | NO |     | NULL |                |
| class  | varchar(10) | YES  | | NULL    | |
| gender | varchar(4) | YES |     | NULL |                |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+----------------+

② 創(chuàng)建tb_1數(shù)據(jù)表,并在表上創(chuàng)建外鍵約束,使其中course_id作為外鍵關(guān)聯(lián)到表st_info5的主鍵st_id

create table tb_1(
    course_id int(8) not null auto_increment,
    course_name varchar(25) not null,
    constraint course_Choosing
    foreign key fk_course(course_id)
    references st_info5(st_id)
)auto_increment=20015001;

mysql> desc tb_1;
+-------------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+----------------+
| course_id | int | NO | MUL | NULL | auto_increment |
| course_name | varchar(25) | NO |     | NULL |                |
+-------------+-------------+------+-----+---------+----------------+

上面語(yǔ)句執(zhí)行成功之后,在表tb_1中添加了course_Choosing的約束名稱,以及外鍵名稱為fk_coursecourse_id字段,依賴于表st_info5的主鍵st_id。

2. 在修改表時(shí)添加外鍵約束

同樣的可以在創(chuàng)建表之后再修改,SQL語(yǔ)句如下:

alter table tb_1 
add 
constraint course_Choosing
foreign key fk_course(course_id)
references st_info5(st_id);

這里需要注意的是,從表的外鍵關(guān)聯(lián)的必須是主表的主鍵,且主鍵和外鍵的數(shù)據(jù)類型必須一致。例如兩者都是int型或者都是char型數(shù)據(jù)。

3. 刪除外鍵約束

當(dāng)一個(gè)表中不需要外鍵約束時(shí),就需要從表中將其刪除。外鍵一旦刪除,就會(huì)解除主表和從表間的關(guān)聯(lián)關(guān)系。

刪除的語(yǔ)法格式:

ALTER TABLE <表名> 
DROP 
FOREIGN KEY <外鍵約束名>;

例:

alter table tb_1
drop
foreign key fk_course;

三. 唯一約束——UNIQUE KEY

唯一約束就是指所有記錄中字段的值不能重復(fù)出現(xiàn),比如給'id'字段加上唯一約束之后,每條記錄的id值都是唯一的,不能出現(xiàn)重復(fù)的情況。

唯一約束與主鍵約束有一個(gè)相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在一個(gè)表中可以有多個(gè),并且設(shè)置唯一約束的列是允許有空值的,雖然只能有一個(gè)空值。

例如,在用戶信息表中,要避免表中的用戶名重名,就可以把用戶名列設(shè)置為唯一約束。

1.在創(chuàng)建表時(shí)設(shè)置唯一約束

唯一約束可以在創(chuàng)建表的時(shí)候直接進(jìn)行設(shè)置,通常設(shè)置在除了主鍵以外的其他列上,語(yǔ)法格式如下:

<字段名> <數(shù)據(jù)類型> UNIQUE

 創(chuàng)建圖書館所有書本明細(xì)表book_info ,設(shè)定書本bk_id為主鍵,書本ISBN為唯一鍵,SQL語(yǔ)句如下:

create table book_info(
    bk_id int primary key,
    ISBN varchar(17) unique,
    author varchar(50),
    Publisher varchar(20)
);

mysql> desc book_info;
+-----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| bk_id | int | NO | PRI | NULL | |
| ISBN | varchar(17) | YES | UNI | NULL |       |
| author | varchar(50) | YES | | NULL | |
| Publisher | varchar(20) | YES |     | NULL |       |
+-----------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

2. 在修改表時(shí)添加唯一約束

語(yǔ)法格式:

ALTER TABLE <數(shù)據(jù)表名> 
ADD 
CONSTRAINT <唯一約束名> UNIQUE(<列名>);

例 將book_info表中author字段設(shè)置為唯一約束:

alter table book_info
add
constraint uni_author unique(author);

mysql> desc book_info;
+-----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| bk_id | int | NO | PRI | NULL | |
| ISBN | varchar(17) | YES | UNI | NULL |       |
| author | varchar(50) | YES | UNI | NULL | |
| Publisher | varchar(20) | YES |     | NULL |       |
+-----------+-------------+------+-----+---------+-------+
4 rows in set (0.01 sec)

3. 刪除唯一約束

語(yǔ)法格式:

ALTER TABLE <表名> 
DROP INDEX <唯一約束名>;

例 刪除book_info表中的唯一約束uni_author;

alter table book_info
drop index uni_author;

mysql> desc book_info;
+-----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| bk_id | int | NO | PRI | NULL | |
| ISBN | varchar(17) | YES | UNI | NULL |       |
| author | varchar(50) | YES | | NULL | |
| Publisher | varchar(20) | YES |     | NULL |       |
+-----------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

四. 檢查約束——CHECK

檢查約束是用來(lái)檢查數(shù)據(jù)表中字段值有效性的一種約束。

例如,學(xué)生信息表中的年齡字段是不能有負(fù)數(shù)的,并且數(shù)值范圍也是有限制的。如果是大學(xué)生,正常年齡一般應(yīng)該在 18~30 歲之間。在設(shè)置字段的檢查約束時(shí)需要根據(jù)實(shí)際情況進(jìn)行設(shè)置,這樣能夠減少無(wú)效數(shù)據(jù)的輸入。

1.在創(chuàng)建表時(shí)設(shè)置檢查約束

語(yǔ)法格式:

CHECK(<約束條件>)

 在persons表創(chuàng)建時(shí)id_p列創(chuàng)建check約束,約束條件為id_p列數(shù)據(jù)必須只包含大于0的整數(shù):

create table persons(
    id_p int not null,
    lastname varchar(255) not null,
    firstname varchar(255),
    address varchar(255),
    city varchar(255),
    check (id_p>0)
);

mysql> desc persons;
+-----------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+-------+
| id_p | int | NO | | NULL | |
| lastname | varchar(255) | NO |     | NULL |       |
| firstname | varchar(255) | YES | | NULL | |
| address | varchar(255) | YES |     | NULL |       |
| city | varchar(255) | YES | | NULL | |
+-----------+--------------+------+-----+---------+-------+

2. 在修改表時(shí)添加檢查約束

語(yǔ)法格式:

ALTER TABLE <表名> 
ADD 
CONSTRAINT <檢查約束名> CHECK(<檢查約束>)

 修改persons數(shù)據(jù)表,要求city字段為“上海”:

create table persons(
    id_p int not null,
    lastname varchar(255) not null,
    firstname varchar(255),
    address varchar(255),
    city varchar(255),
    constraint chk_person check (id_p>0 and city='sandnes')
);

alter table persons 
add 
constraint chk_ct check(city='上海');

mysql> desc persons;
+-----------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+-------+
| id_p | int | NO | | NULL | |
| lastname | varchar(255) | NO |     | NULL |       |
| firstname | varchar(255) | YES | | NULL | |
| address | varchar(255) | YES |     | NULL |       |
| city | varchar(255) | YES | | NULL | |
+-----------+--------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

3. 刪除檢查約束

語(yǔ)法格式:

ALTER TABLE <表名> 
DROP CONSTRAINT <檢查約束名>;

 刪除persons表中的check_ct約束:

alter table persons 
drop constraint chk_ct;

五. 非空約束——NOT NULL

非空約束是用來(lái)約束表中的字段不能為空。在表中某個(gè)列的定義后加上關(guān)鍵字NOT NULL作為限定詞,來(lái)約束該列的取值不能為空。

例如,在學(xué)生信息表中,如果不添加學(xué)生姓名,那么這條記錄是無(wú)效的,這種情況下就可以為用戶名字段設(shè)置非空約束。

1.在創(chuàng)建表時(shí)設(shè)置非空約束

語(yǔ)法格式:

CREATE TABLE <表名>(
    ...
<字段名> <數(shù)據(jù)類型> NOT NULL)
...
);

例 創(chuàng)建學(xué)生信息表st_info, 指定st_id為主鍵,學(xué)生姓名不能為空:

create table st_info(
    st_id int(10) primary key,
    name varchar(20) not null,
    class varchar(10),
    gender varchar(4),
    age int(2)
);

mysql> desc st_info;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class  | varchar(10) | YES  | | NULL    | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

2. 在修改表時(shí)添加非空約束:

如果在創(chuàng)建表的時(shí)候忘記了為字段設(shè)置非空約束,可以通過(guò)修改表進(jìn)行非空約束的添加。

語(yǔ)法格式:

ALTER TABLE <表名>
CHANGE COLUMN <字段名>
<字段名> <數(shù)據(jù)類型> NOT NULL;

 修改學(xué)生信息表st_info中class字段,設(shè)置成非空約束:

mysql> alter table st_info
    -> change column class
    -> class varchar(20) not null;
Query OK, 0 rows affected (0.06 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc st_info;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class  | varchar(20) | NO   | | NULL    | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

3. 刪除非空約束

可以在修改語(yǔ)句中對(duì)非空約束進(jìn)行刪除。

語(yǔ)法格式:

ALTER TABLE <數(shù)據(jù)表名>
CHANGE COLUMN <字段名> 
<字段名> <數(shù)據(jù)類型> NULL;

 修改學(xué)生信息表st_info,將class字段的非空約束刪除:

mysql> alter table st_info
    -> change column class
    -> class varchar(20) null;
Query OK, 0 rows affected (0.04 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc st_info;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class  | varchar(20) | YES  | | NULL    | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

六. 默認(rèn)值約束——DEFAULT

默認(rèn)值約束是當(dāng)數(shù)據(jù)表中某個(gè)字段不輸入值的時(shí)候,自動(dòng)為其添加一個(gè)已經(jīng)設(shè)置好的值。

例如,在注冊(cè)學(xué)生信息時(shí),如果不輸入學(xué)生的性別,那么會(huì)默認(rèn)設(shè)置一個(gè)性別或者輸入一個(gè)“未知”。

默認(rèn)值約束一般是用在已經(jīng)設(shè)置了非空約束的列,這樣能夠防止數(shù)據(jù)表在錄入數(shù)據(jù)時(shí)出現(xiàn)錯(cuò)誤。

1.在創(chuàng)建表時(shí)設(shè)置默認(rèn)值約束

語(yǔ)法格式:

CREATE TABLE <表名>(
    ...
<字段名> <數(shù)據(jù)類型> DEFAULT <默認(rèn)值>
    ...
);

 創(chuàng)建學(xué)生信息表st_info,設(shè)置年齡age默認(rèn)值為18:

create table st_info(
    st_id int(10) primary key,
    name varchar(20) not null,
    class varchar(10),
    gender varchar(4),
    age int(2) default 18
);

mysql> desc st_info;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class  | varchar(10) | YES  | | NULL    | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | 18      | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.01 sec)

2. 在修改表時(shí)添加默認(rèn)值約束

語(yǔ)法格式:

ALTER TABLE <數(shù)據(jù)表名>
CHANGE COLUMN <字段名> 
<字段名> <數(shù)據(jù)類型> DEFAULT <默認(rèn)值>;

 修改學(xué)生信息表st_info,將性別設(shè)置默認(rèn)值為“保密”:

mysql> alter table st_info
    -> change column gender
    -> gender varchar(4) default '保密';
Query OK, 0 rows affected (0.02 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc st_info;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class  | varchar(10) | YES  | | NULL    | |
| gender | varchar(4) | YES |     | 保密 |       |
| age | int | YES | | 18      | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

需要注意的是,這里的gender字段為字符串型數(shù)據(jù),需要加上引號(hào)。

3. 刪除默認(rèn)值

刪除默認(rèn)值即為將默認(rèn)值設(shè)置為空(null)

語(yǔ)法格式:

ALTER TABLE <數(shù)據(jù)表名>
CHANGE COLUMN <字段名> 
<字段名> <數(shù)據(jù)類型> DEFAULT NULL;

 修改學(xué)生信息表st_info, 將gender性別字段的默認(rèn)值刪除掉:

mysql> alter table st_info
    -> change column gender
    -> gender varchar(4) default null;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc st_info;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| st_id | int | NO | PRI | NULL | |
| name | varchar(20) | NO |     | NULL |       |
| class  | varchar(10) | YES  | | NULL    | |
| gender | varchar(4) | YES |     | NULL |       |
| age | int | YES | | 18      | |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

以上6個(gè)約束都很重要,并且有的可以聯(lián)合使用,并不是都是單獨(dú)使用的。作為基礎(chǔ)知識(shí)點(diǎn),會(huì)讓你的數(shù)據(jù)庫(kù)更加規(guī)范,從而提高工作效率。

總結(jié)

到此這篇關(guān)于MySQL數(shù)據(jù)庫(kù)表約束的文章就介紹到這了,更多相關(guān)MySQL表約束內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 初始化MySQL用戶(刪除匿名用戶)

    初始化MySQL用戶(刪除匿名用戶)

    安裝完MySQL后,系統(tǒng)默認(rèn)會(huì)創(chuàng)建一個(gè)不需要密碼的root用戶,和一個(gè)無(wú)用戶名無(wú)密碼的匿名用戶(Anonymous Account)。進(jìn)行下面的初始化操作以合理授權(quán),增強(qiáng)安全
    2016-01-01
  • mysql 數(shù)據(jù)庫(kù)備份的多種實(shí)現(xiàn)方式總結(jié)

    mysql 數(shù)據(jù)庫(kù)備份的多種實(shí)現(xiàn)方式總結(jié)

    這篇文章主要介紹了mysql 數(shù)據(jù)庫(kù)備份的多種實(shí)現(xiàn)方式,總結(jié)分析了MySQL數(shù)據(jù)庫(kù)備份的常見語(yǔ)句、使用方法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-02-02
  • mysql中判斷記錄是否存在方法比較

    mysql中判斷記錄是否存在方法比較

    把數(shù)據(jù)寫入到數(shù)據(jù)庫(kù)的時(shí),常常會(huì)碰到先要檢測(cè)要插入的記錄是否存在,然后決定是否要寫入。
    2011-07-07
  • MySQL中動(dòng)態(tài)生成SQL語(yǔ)句去掉所有字段的空格的操作方法

    MySQL中動(dòng)態(tài)生成SQL語(yǔ)句去掉所有字段的空格的操作方法

    在數(shù)據(jù)庫(kù)管理過(guò)程中,我們常常會(huì)遇到需要對(duì)表中字段進(jìn)行清洗和整理的情況,本文將詳細(xì)介紹如何在MySQL中動(dòng)態(tài)生成SQL語(yǔ)句來(lái)去掉所有字段的空格,感興趣的朋友一起看看吧
    2025-04-04
  • linux下 root 登錄 MySQL 報(bào)錯(cuò)的問(wèn)題

    linux下 root 登錄 MySQL 報(bào)錯(cuò)的問(wèn)題

    本文給大家記錄的是個(gè)人在linux下使用root用戶登錄mysql的時(shí)候遇到的一個(gè)錯(cuò)誤的解決方法,非常的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。
    2016-02-02
  • MySQL登錄、訪問(wèn)及退出操作實(shí)戰(zhàn)指南

    MySQL登錄、訪問(wèn)及退出操作實(shí)戰(zhàn)指南

    當(dāng)我們要使用mysql時(shí),一定要了解mysql的登錄、訪問(wèn)及退出,下面這篇文章主要給大家介紹了關(guān)于MySQL登錄、訪問(wèn)及退出操作的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10
  • MySQL數(shù)據(jù)庫(kù)數(shù)據(jù)塊大小及配置方法

    MySQL數(shù)據(jù)庫(kù)數(shù)據(jù)塊大小及配置方法

    MySQL作為一種流行的關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng),在處理大規(guī)模數(shù)據(jù)存儲(chǔ)和查詢時(shí),數(shù)據(jù)塊(data block)大小是一個(gè)至關(guān)重要的因素,本文將詳細(xì)探討MySQL數(shù)據(jù)庫(kù)的數(shù)據(jù)塊大小,結(jié)合實(shí)際例子說(shuō)明其重要性和配置方法,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • 防止MySQL重復(fù)插入數(shù)據(jù)的三種方法

    防止MySQL重復(fù)插入數(shù)據(jù)的三種方法

    在MySQL進(jìn)行數(shù)據(jù)插入操作時(shí),總是會(huì)考慮是否會(huì)插入重復(fù)數(shù)據(jù),之前的操作都是先根據(jù)主鍵或者唯一約束條件進(jìn)行查詢,有就進(jìn)行更新沒(méi)有就進(jìn)行插入。代碼反復(fù)效率低下。
    2020-09-09
  • mysql在項(xiàng)目中怎么選事務(wù)隔離級(jí)別

    mysql在項(xiàng)目中怎么選事務(wù)隔離級(jí)別

    Mysql默認(rèn)的事務(wù)隔離級(jí)別是可重復(fù)讀,那互聯(lián)網(wǎng)項(xiàng)目中Mysql也是用默認(rèn)隔離級(jí)別,但在項(xiàng)目中呢,下面我們就一起來(lái)了解一下
    2021-05-05
  • MySQL數(shù)據(jù)庫(kù)node使用詳解

    MySQL數(shù)據(jù)庫(kù)node使用詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)node使用,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06

最新評(píng)論