1.完整性約束
1)完整性約束的定義
爲了保證插入數據的正確性
和合法性
,給表中字段添加,除了數據類型約束
以外的【其他約束條件】。
2)完整性約束的分類
① 實體完整性:記錄之間不能重複。
主鍵約束(primary key)
:唯一併且不能爲空;唯一約束(unique)
:唯一可以爲空;主鍵自增(auto_increment)
② 域完整性:數據庫表的字段,必須符合某種特定的數據類型或約束。
類型約束
:在創建表的時候,已經給每個字段添加類型了;非空約束
:not null;默認值
:default;
③ 引用完整性(參照完整性):一張表中字段的值,需要參考另外一張表中的值。
添加外鍵約束
:foreign key- 引用完整性會降低sql的執行效率,有時候能不用就不用。
2.主鍵約束(primary key)
主鍵約束(primary key)
:唯一併且不能爲空;- 一張表只能有一個主鍵字段,但是可以有聯合主鍵;
添加主鍵約束,有以下3種方式:
方式一:在創建表的同時,添加主鍵約束。
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);
方式二:在創建表的同時,添加主鍵約束,但是添加方式不同。
"只有這種添加主鍵的方式,可以添加聯合主鍵"
create table student(
sid int,
sname varchar(20),
age int,
primary key(sid)
)charset=utf8;
方式三:創建完表後,添加主鍵約束。
create table student(
sid int,
sname varchar(20),
age int
)charset=utf8;
alter table student add primary key(sid);
-- constraint表示添加的是一個約束;
-- pk_sid是給約束起一個名字;
1)單個主鍵和聯合主鍵的區別
"單個主鍵"
將表中某一個字段設置爲主鍵,用這一個字段,來唯一確定一條記錄。
只要sid唯一不爲空,每一行就是一條唯一的記錄。
primary key(sid)
sid sname age
1 張三 18
2 張三 18
"聯合主鍵"
將表中2個字段(或多個字段)設置爲聯合主鍵,用這2個字段(或多個字段),
來唯一確定一條記錄。
這2個字段可以分別重複,只要不是同時重複即可。
primary key(sid,classid)
sid classid sname age
1 2 張三 18
1 3 張三 18
2 4 李四 20
3 4 王五 30
-- 下面兩條記錄,聯合字段同時重複,表示一條重複記錄,插入時報錯。
5 5 李闖 25
5 5 王二 24
2)主鍵字段的挑選原則
- 一:通常選擇無意義的字段作爲主鍵字段,比如說表中記錄每一行行號的id字段,就是無意義的字段,很適合作爲主鍵;
- 二:主鍵字段一般不會對其進行修改(像字段名、字段類型等);
- 三:經常變化的字段,有意義的字段,不適合作爲主鍵;
特別注意:
當一個建表語句中,某個字段只有primary key限制,而沒有使用主鍵自增(auto_increament),
需要我們自己給主鍵字段插入值,否則會出現如下錯誤。
"ERROR 1364 (HY000): Field 'sid' doesn't have a default value"
但是我們上面說過,主鍵字段一般是不進行修改的,也就是說不要主動給他值,主鍵字段應該是讓系
統默認賦值。這個在學習過`主鍵自增`後你就明白了。
記住:primary key和auto_increament最好配合使用。
舉例說明:
3)刪除主鍵約束
alter table student drop primary key;
3.主鍵自增(auto_increment)
1)主鍵自增的含義和特點
見名知意,這個是用來幫助主鍵自動添加值
的一個約束。上面我們說過,主鍵字段最好不要有任何改動,當然也包括給主鍵字段插入數值的時候,也不要手動去添加主鍵,而是讓系統自動給主鍵字段進行賦值。主鍵自增有如下2個特點:
- 一:設置了主鍵自增後,主鍵值會從1開始,每次自增1;
- 二:以前用過的主鍵值,當你刪除該行記錄後,主鍵值仍然是一個新的值,並不會重複使用以前出現過的主鍵值。
對第二個特點的說明:
添加唯一約束,有以下2種方式:
方式一:創建表的時候,在添加主鍵的同時,添加主鍵自增。
create table student(
sid int primary key auto_increment,
sname varchar(20),
age int,
idcard varchar(18)
)charset=utf8;
-- primary key和auto_increment配合使用,插入數據的時候,
-- 不需要給主鍵字段sid賦值了。
insert into student(sname,age) values ("張三",22),("李四",25);
方式二:創建完表後,給字段同時添加"主鍵和主鍵自增"。
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;
2)刪除主鍵自增
alter table student modify sid int primary key;
4.唯一約束(unique)
1)唯一性約束的含義
由於一張表中只能由一個主鍵。但是對於某些字段,像身份證
這樣的字段,肯定也是唯一的,我們不能又將其設置爲主鍵(身份證字段屬於有意義的字段),那麼怎麼保證它的唯一性呢?這就是接下來要講述的唯一約束
。注意:一張表可以有多個唯一約束。
添加唯一約束,有以下3種方式:
方式一:在創建表的同時,添加唯一約束。
create table student(
sid int primary key key auto_increment,
sname varchar(20),
age int,
idcard varchar(18) unique
)charset=utf8;
-- 設置了唯一約束的字段,當插入相同的值,會報錯。
insert into student(sname,age,idcard) values ("李四",18,"123456");
insert into student(sname,age,idcard) values ("王五",22,"123456");
方式二:在創建表的同時,添加唯一約束,但是添加方式不同。
"只有這種添加主鍵的方式,可以添加聯合主鍵"
create table student (
sid int primary key auto_increment,
sname varchar(20),
age int,
idcard varchar(18),
unique(idcard)
)charset=utf8;
方式三:創建完表後,添加唯一約束。
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);
2)刪除唯一約束
'刪除唯一約束,使用的語句有點不同,記住。'
alter table student drop key idcard;
5.添加非空約束(not null)
1)怎麼添加非空約束?
非空約束
指的是我們給某個字段設置了非空約束後,當我們給該字段插入空值的時候,會報錯。添加非空約束,有以下2種方式:
方式一:創建表的時候,給字段添加非空約束。
create table student(
sid int primary key auto_increment,
sname varchar(20) not null,
age int,
idcard varchar(18)
)charset=utf8;
方式二:創建完表後,給字段添加非空約束。
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;
2)字段添加非空約束後具有如下特點
"這些細節知識,有時候是我們沒有注意到的,因此單獨拿出來說明。"
一:字段設置了非空約束後,你不能插入null值。
-- 下面這樣插入會報錯。
insert into student(sname,age) values (null,22);
二:字段設置了非空約束後,不但不能插入null值,而且還不能不插入值。
-- 下面這樣插入也會報錯。
insert into student(age,idcard) values (33,"123456789");
舉例如下:
6.添加默認值約束(default)
某個字段當被設置了默認值
以後,當我們不爲該字段指定值的時候,就會顯示這個默認值。
1)怎麼添加默認值約束?
方式一:創建表的時候,給字段添加默認值。
create table student(
sid int primary key auto_increment,
sname varchar(20),
age int default 0,
idcard varchar(18)
)charset=utf8;
方式二:創建完表後,給字段添加默認值。
create table student(
sid int primary key auto_increment,
sname varchar(20),
age int,
idcard varchar(18)
)charset=utf8;
"不同點,需要特別留意"
-- 使用alter添加默認值的代碼有點特別。
alter table student alter age set default 0;
2)刪除默認值
alter table student alter column age drop default;
7.引用完整性(參照完整性)
1)什麼是引用完整性?
引用完整性
指的是,一張表中字段的取值,需要參照另一張表中某個字段的取值。這裏涉及到的就是外鍵
:foreign key
。一般情況下,本表中的這個字段設置的是外鍵foreign key,參考表中的那個字段的取值,就需要設置爲那個表的主鍵。下面我們用一張圖帶着大家理解:
特別注意:
2)添加外鍵約束(foreign key)
需要記住一句話:先有被引用的表,然後纔可以給當前表添加外鍵約束,否則,你引用誰去?添加外鍵約束,有以下2種方式:
方式一:創建表的時候,給字段添加外鍵約束。
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;
方式二:創建完表後,給字段添加外鍵約束。
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相當於起的別名。"
關注微信公衆號『數據分析與統計學之美』,後臺回覆“入羣”拉你入羣交流哦,氣氛槓槓的!看到這裏,麻煩您點個再看,讓更多朋友看到哦!