MySQL完整性約束的定義與實(shí)例教程
完整性約束
完整性約束的定義
為了保證插入數(shù)據(jù)的正確性和合法性,給表中字段添加,除了 數(shù)據(jù)類型約束 以外的 其他約束條件 。
完整性約束的分類
實(shí)體完整性:記錄之間不能重復(fù)。
- 主鍵約束(primary key) :唯一并且不能為空
- 唯一約束(unique) :唯一可以為空
- 主鍵自增(auto_increment)
域完整性:數(shù)據(jù)庫表的字段,必須符合某種特定的數(shù)據(jù)類型或約束。
- 類型約束 :在創(chuàng)建表的時候,已經(jīng)給每個字段添加類型了
- 非空約束 :not null
- 默認(rèn)值 :default
引用完整性(參照完整性):一張表中字段的值,需要參考另外一張表中的值。
- 添加外鍵約束:foreign key
- 引用完整性會降低sql的執(zhí)行效率,有時候能不用就不用。
主鍵約束(primary key)
- 主鍵約束(primary key) :唯一并且不能為空;
- 一張表只能有一個主鍵字段,但是可以有聯(lián)合主鍵;
添加主鍵約束,有以下3種方式:
方式一:在創(chuàng)建表的同時,添加主鍵約束。 create table student( sid int primary key, sname varchar(20), age int )charset=utf8; -- 添加主鍵約束后,插入相同的sid,會報錯。 insert into student(sid,sname,age) values (1,'張三',22); insert into student(sid,sname,age) values (1,'李四',33); 方式二:在創(chuàng)建表的同時,添加主鍵約束,但是添加方式不同。 "只有這種添加主鍵的方式,可以添加聯(lián)合主鍵" create table student( sid int, sname varchar(20), age int, primary key(sid) )charset=utf8; 方式三:創(chuàng)建完表后,添加主鍵約束。 create table student( sid int, sname varchar(20), age int )charset=utf8; alter table student add primary key(sid); -- constraint表示添加的是一個約束; -- pk_sid是給約束起一個名字;
單個主鍵和聯(lián)合主鍵的區(qū)別
"單個主鍵" 將表中某一個字段設(shè)置為主鍵,用這一個字段,來唯一確定一條記錄。 只要sid唯一不為空,每一行就是一條唯一的記錄。 primary key(sid) sid sname age 1 張三 18 2 張三 18 "聯(lián)合主鍵" 將表中2個字段(或多個字段)設(shè)置為聯(lián)合主鍵,用這2個字段(或多個字段), 來唯一確定一條記錄。 這2個字段可以分別重復(fù),只要不是同時重復(fù)即可。 primary key(sid,classid) sid classid sname age 1 2 張三 18 1 3 張三 18 2 4 李四 20 3 4 王五 30 -- 下面兩條記錄,聯(lián)合字段同時重復(fù),表示一條重復(fù)記錄,插入時報錯。 5 5 李闖 25 5 5 王二 24
主鍵字段的挑選原則
- 通常選擇無意義的字段作為主鍵字段,比如說表中記錄每一行行號的id字段,就是無意義的字段,很適合作為主鍵
- 主鍵字段一般不會對其進(jìn)行修改(像字段名、字段類型等)
- 經(jīng)常變化的字段,有意義的字段,不適合作為主鍵
特別注意:當(dāng)一個建表語句中,某個字段只有primary key限制,而沒有使用主鍵自增 auto_increament
需要我們自己給主鍵字段插入值,否則會出現(xiàn)如下錯誤。 "ERROR 1364 (HY000): Field 'sid' doesn't have a default value"
但是我們上面說過,主鍵字段一般是不進(jìn)行修改的,也就是說不要主動給他值,主鍵字段應(yīng)該是讓系
統(tǒng)默認(rèn)賦值。這個在學(xué)習(xí)過 主鍵自增 后你就明白了。
記?。?primary key 和 auto_increament 最好配合使用。
舉例說明:
刪除主鍵約束
alter table student drop primary key;
主鍵自增(auto_increment)
主鍵自增的含義和特點(diǎn)
見名知意,這個是用來 幫助主鍵自動添加值 的一個約束。上面我們說過,主鍵字段最好不要有任何改動,當(dāng)然也包括給主鍵字段插入數(shù)值的時候,也不要手動去添加主鍵,而是讓系統(tǒng)自動給主鍵字段進(jìn)行賦值。主鍵自增有如下2個特點(diǎn):
- 設(shè)置了主鍵自增后,主鍵值會從1開始,每次自增1。
- 以前用過的主鍵值,當(dāng)你刪除該行記錄后,主鍵值仍然是一個新的值,并不會重復(fù)使用以前出現(xiàn)過的主鍵值。
對第二個特點(diǎn)的說明:
添加唯一約束,有以下2種方式:
方式一:創(chuàng)建表的時候,在添加主鍵的同時,添加主鍵自增。 create table student( sid int primary key auto_increment, sname varchar(20), age int, idcard varchar(18) )charset=utf8; -- primary key和auto_increment配合使用,插入數(shù)據(jù)的時候, -- 不需要給主鍵字段sid賦值了。 insert into student(sname,age) values ("張三",22),("李四",25); 方式二:創(chuàng)建完表后,給字段同時添加"主鍵和主鍵自增"。 create table student( sid int, sname varchar(20), age int, idcard varchar(18) )charset=utf8; -- 以下2種方式,均可以給字段同時添加"主鍵和主鍵自增"。 alter table student modify sid int primary key auto_increment; alter table student change sid sid int primary key auto_increment;
刪除主鍵自增
alter table student modify sid int primary key;
唯一約束(unique)
唯一性約束的含義
由于一張表中只能由一個主鍵。但是對于某些字段,像 身份證 這樣的字段,肯定也是唯一的,我們不能又將其設(shè)置為主鍵(身份證字段屬于有意義的字段),那么怎么保證它的唯一性呢?這就是接下來要講述的 唯一約束 。注意:一張表可以有多個唯一約束。
添加唯一約束,有以下3種方式:
方式一:在創(chuàng)建表的同時,添加唯一約束。 create table student( sid int primary key key auto_increment, sname varchar(20), age int, idcard varchar(18) unique )charset=utf8; 方式二:在創(chuàng)建表的同時,添加唯一約束,但是添加方式不同。 "只有這種添加主鍵的方式,可以添加聯(lián)合主鍵" create table student ( sid int primary key auto_increment, sname varchar(20), age int, idcard varchar(18), unique(idcard) )charset=utf8; 方式三:創(chuàng)建完表后,添加唯一約束。 create table student ( sid int primary key auto_increment, sname varchar(20), age int, idcard varchar(18) )charset=utf8; alter table student add unique(idcard); -- 設(shè)置了唯一約束的字段,當(dāng)插入相同的值,會報錯。 insert into student(sname,age,idcard) values ("李四",18,"123456"); insert into student(sname,age,idcard) values ("王五",22,"123456");
刪除唯一約束
刪除唯一約束,使用的語句有點(diǎn)不同。 alter table student drop key idcard;
添加非空約束(not null)
添加非空約束
非空約束指的是我們給某個字段設(shè)置了非空約束后,當(dāng)我們給該字段插入空值的時候,會報錯。添加非空約束,有以下2種方式:
方式一:創(chuàng)建表的時候,給字段添加非空約束。 create table student( sid int primary key auto_increment, sname varchar(20) not null, age int, idcard varchar(18) )charset=utf8; 方式二:創(chuàng)建完表后,給字段添加非空約束。 create table student( sid int primary key auto_increment, sname varchar(20), age int, idcard varchar(18) )charset=utf8; -- 有以下兩種添加方式。 alter table student modify sname varchar(20) not null; alter table student change sname sname varchar(20) not null;
字段添加非空約束后具有如下特點(diǎn)
- 字段設(shè)置了非空約束后,你不能插入null值。
- 字段設(shè)置了非空約束后,不但不能插入null值,而且還不能不插入值
"這些細(xì)節(jié)知識,有時候是我們沒有注意到的,因此單獨(dú)拿出來說明。" 一:字段設(shè)置了非空約束后,你不能插入null值。 -- 下面這樣插入會報錯。 insert into student(sname,age) values (null,22); 二:字段設(shè)置了非空約束后,不但不能插入null值,而且還不能不插入值。 -- 下面這樣插入也會報錯。 insert into student(age,idcard) values (33,"123456789");
舉例如下:
添加默認(rèn)值約束(default)
某個字段當(dāng)被設(shè)置了 默認(rèn)值 以后,當(dāng)我們不為該字段指定值的時候,就會顯示這個默認(rèn)值。
添加默認(rèn)值約束
方式一:創(chuàng)建表的時候,給字段添加默認(rèn)值。 create table student( sid int primary key auto_increment, sname varchar(20), age int default 0, idcard varchar(18) )charset=utf8; 方式二:創(chuàng)建完表后,給字段添加默認(rèn)值。 create table student( sid int primary key auto_increment, sname varchar(20), age int, idcard varchar(18) )charset=utf8; "不同點(diǎn),需要特別留意" -- 使用alter添加默認(rèn)值的代碼有點(diǎn)特別。 alter table student alter age set default 0;
刪除默認(rèn)值
alter table student alter column age drop default;
引用完整性(參照完整性)
什么是引用完整性?
引用完整性指的是,一張表中字段的取值,需要參照另一張表中某個字段的取值。這里涉及到的就是 外鍵 : foreign key 。一般情況下,本表中的這個字段設(shè)置的是外鍵 foreign key ,參考表中的那個字段的取值,就需要設(shè)置為那個表的主鍵。
參考下圖幫助理解:
特別注意:學(xué)生表中的 cid 參考的是班級表中的 cid ,可以看到,這里的字段名是完全一樣的。但是,實(shí)際上,這兩個字段名可以不一樣,但是這兩個字段的數(shù)據(jù)類型必須是一樣的
構(gòu)成引用完整性的條件:
- 一張表(參照表)中的某個字段,參照另一張表(被參照表)中的字段(字段名可以不同)。
- 兩張表中的字段名可以不同,但是字段的數(shù)據(jù)類型必須一致。
- 參照表中的字段在該表中是 foreign key 。被參照表中的字段在該表中是 primary key 。
添加外鍵約束(foreign key)
需要記住一句話:先有被引用的表,然后才可以給當(dāng)前表添加外鍵約束,否則,你引用誰去?
添加外鍵約束,有以下2種方式:
方式一:創(chuàng)建表的時候,給字段添加外鍵約束。 create table classroom( cid int primary key auto_increment, cname varchar(20) not null )charset=utf8; create table student( sid int primary key auto_increment, sname varchar(20) not null, age bit(1), cid int, constraint fk_cid foreign key(cid) references classroom(cid) )charset=utf8; 方式二:創(chuàng)建完表后,給字段添加外鍵約束。 create table classroom( cid int primary key, cname varchar(20) not null )charset=utf8; create table student( sid int primary key auto_increment, sname varchar(20) not null, age bit(1), cid int )charset=utf8; alter table student add constraint fk_cid foreign key(cid) references classroom(cid); "注意:constraint后面接的是別名,fk_cid相當(dāng)于起的別名。"
總結(jié)
到此這篇關(guān)于MySQL完整性約束的文章就介紹到這了,更多相關(guān)MySQL完整性約束內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql優(yōu)化之慢查詢分析+explain命令分析+優(yōu)化技巧總結(jié)
這篇文章主要介紹了mysql優(yōu)化之慢查詢分析,explain命令分析,優(yōu)化技巧總結(jié),需要的朋友可以參考下2023-02-02MySQL 文本文件的導(dǎo)入導(dǎo)出數(shù)據(jù)的方法
但有時為了更快速地插入大批量數(shù)據(jù)或交換數(shù)據(jù),需要從文本中導(dǎo)入數(shù)據(jù)或?qū)С鰯?shù)據(jù)到文本。下面的具體的方法大家可以參考下。多測試。2009-11-11修改MySQL密碼的四種方法總結(jié)(適合初學(xué)者!)
在日常使用數(shù)據(jù)庫的過程中,難免會遇到需要修改賬號密碼的情景,比如密碼太簡單需要修改、密碼過期需要修改、忘記密碼需要修改等,下面這篇文章主要給大家介紹了關(guān)于修改MySQL密碼的四種方法,介紹的方法非常適合初學(xué)者,需要的朋友可以參考下2022-08-08關(guān)于MySQL死鎖的產(chǎn)生原因、檢測與解決方式
這篇文章主要介紹了關(guān)于MySQL死鎖的產(chǎn)生原因、檢測與解決方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07mysql 常用設(shè)置 字符集編碼、自動完成(自動提示)、監(jiān)聽外網(wǎng)ip
mysql 常用設(shè)置 字符集編碼、自動完成(自動提示)、監(jiān)聽外網(wǎng)ip,需要的朋友可以參考下2012-07-07Linux上通過binlog文件恢復(fù)mysql數(shù)據(jù)庫詳細(xì)步驟
binglog文件是服務(wù)器的二進(jìn)制日志記錄著該數(shù)據(jù)庫的所有增刪改的操作日志,接下來通過本文給大家介紹linux上通過binlog文件恢復(fù)mysql數(shù)據(jù)庫詳細(xì)步驟,非常不錯,需要的朋友參考下2016-08-08