濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > MySQL完整性約束的定義與實(shí)例教程

MySQL完整性約束的定義與實(shí)例教程

熱門(mén)標(biāo)簽:400電話變更申請(qǐng) 400電話辦理服務(wù)價(jià)格最實(shí)惠 大豐地圖標(biāo)注app 催天下外呼系統(tǒng) 北京金倫外呼系統(tǒng) html地圖標(biāo)注并導(dǎo)航 呂梁外呼系統(tǒng) 南太平洋地圖標(biāo)注 武漢電銷機(jī)器人電話

完整性約束

完整性約束的定義

為了保證插入數(shù)據(jù)的正確性和合法性,給表中字段添加,除了 數(shù)據(jù)類型約束 以外的 其他約束條件 。

完整性約束的分類

實(shí)體完整性:記錄之間不能重復(fù)。

  • 主鍵約束(primary key) :唯一并且不能為空
  • 唯一約束(unique) :唯一可以為空
  • 主鍵自增(auto_increment)

域完整性:數(shù)據(jù)庫(kù)表的字段,必須符合某種特定的數(shù)據(jù)類型或約束。

  • 類型約束 :在創(chuàng)建表的時(shí)候,已經(jīng)給每個(gè)字段添加類型了
  • 非空約束 :not null
  • 默認(rèn)值 :default

引用完整性(參照完整性):一張表中字段的值,需要參考另外一張表中的值。

  • 添加外鍵約束:foreign key
  • 引用完整性會(huì)降低sql的執(zhí)行效率,有時(shí)候能不用就不用。

主鍵約束(primary key)

  • 主鍵約束(primary key) :唯一并且不能為空;
  • 一張表只能有一個(gè)主鍵字段,但是可以有聯(lián)合主鍵;

添加主鍵約束,有以下3種方式:

方式一:在創(chuàng)建表的同時(shí),添加主鍵約束。
create table student(
    sid int primary key,
    sname varchar(20),
    age int
)charset=utf8;
-- 添加主鍵約束后,插入相同的sid,會(huì)報(bào)錯(cuò)。
insert into student(sid,sname,age) values (1,'張三',22);
insert into student(sid,sname,age) values (1,'李四',33);

方式二:在創(chuàng)建表的同時(shí),添加主鍵約束,但是添加方式不同。
  "只有這種添加主鍵的方式,可以添加聯(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表示添加的是一個(gè)約束;      
-- pk_sid是給約束起一個(gè)名字;

單個(gè)主鍵和聯(lián)合主鍵的區(qū)別

"單個(gè)主鍵"
    將表中某一個(gè)字段設(shè)置為主鍵,用這一個(gè)字段,來(lái)唯一確定一條記錄。
    只要sid唯一不為空,每一行就是一條唯一的記錄。
    primary key(sid)
    sid   sname   age
    1     張三    18
    2     張三    18  

"聯(lián)合主鍵"
    將表中2個(gè)字段(或多個(gè)字段)設(shè)置為聯(lián)合主鍵,用這2個(gè)字段(或多個(gè)字段),
    來(lái)唯一確定一條記錄。
    這2個(gè)字段可以分別重復(fù),只要不是同時(shí)重復(fù)即可。
    primary key(sid,classid)
    sid   classid   sname   age
    1     2         張三    18
    1     3         張三    18  
    2     4         李四    20
    3     4         王五    30
    -- 下面兩條記錄,聯(lián)合字段同時(shí)重復(fù),表示一條重復(fù)記錄,插入時(shí)報(bào)錯(cuò)。
    5     5         李闖    25  
    5     5         王二    24

主鍵字段的挑選原則

  1. 通常選擇無(wú)意義的字段作為主鍵字段,比如說(shuō)表中記錄每一行行號(hào)的id字段,就是無(wú)意義的字段,很適合作為主鍵
  2. 主鍵字段一般不會(huì)對(duì)其進(jìn)行修改(像字段名、字段類型等)
  3. 經(jīng)常變化的字段,有意義的字段,不適合作為主鍵

特別注意:當(dāng)一個(gè)建表語(yǔ)句中,某個(gè)字段只有primary key限制,而沒(méi)有使用主鍵自增 auto_increament
需要我們自己給主鍵字段插入值,否則會(huì)出現(xiàn)如下錯(cuò)誤。 "ERROR 1364 (HY000): Field 'sid' doesn't have a default value"

但是我們上面說(shuō)過(guò),主鍵字段一般是不進(jìn)行修改的,也就是說(shuō)不要主動(dòng)給他值,主鍵字段應(yīng)該是讓系
統(tǒng)默認(rèn)賦值。這個(gè)在學(xué)習(xí)過(guò) 主鍵自增 后你就明白了。

記?。?primary key 和 auto_increament 最好配合使用。

舉例說(shuō)明:

刪除主鍵約束

alter table student drop primary key;


主鍵自增(auto_increment)

主鍵自增的含義和特點(diǎn)

見(jiàn)名知意,這個(gè)是用來(lái) 幫助主鍵自動(dòng)添加值 的一個(gè)約束。上面我們說(shuō)過(guò),主鍵字段最好不要有任何改動(dòng),當(dāng)然也包括給主鍵字段插入數(shù)值的時(shí)候,也不要手動(dòng)去添加主鍵,而是讓系統(tǒng)自動(dòng)給主鍵字段進(jìn)行賦值。主鍵自增有如下2個(gè)特點(diǎn):

  1. 設(shè)置了主鍵自增后,主鍵值會(huì)從1開(kāi)始,每次自增1。
  2. 以前用過(guò)的主鍵值,當(dāng)你刪除該行記錄后,主鍵值仍然是一個(gè)新的值,并不會(huì)重復(fù)使用以前出現(xiàn)過(guò)的主鍵值。

對(duì)第二個(gè)特點(diǎn)的說(shuō)明:

添加唯一約束,有以下2種方式:

方式一:創(chuàng)建表的時(shí)候,在添加主鍵的同時(shí),添加主鍵自增。 
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ù)的時(shí)候,
-- 不需要給主鍵字段sid賦值了。
insert into student(sname,age) values ("張三",22),("李四",25);

方式二:創(chuàng)建完表后,給字段同時(shí)添加"主鍵和主鍵自增"。
create table student(
   sid int,
   sname varchar(20),
   age int,
   idcard varchar(18) 
)charset=utf8;  
-- 以下2種方式,均可以給字段同時(shí)添加"主鍵和主鍵自增"。
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)

唯一性約束的含義

由于一張表中只能由一個(gè)主鍵。但是對(duì)于某些字段,像 身份證 這樣的字段,肯定也是唯一的,我們不能又將其設(shè)置為主鍵(身份證字段屬于有意義的字段),那么怎么保證它的唯一性呢?這就是接下來(lái)要講述的 唯一約束 。注意:一張表可以有多個(gè)唯一約束。

添加唯一約束,有以下3種方式:

方式一:在創(chuàng)建表的同時(shí),添加唯一約束。
create table student(
    sid int primary key key auto_increment,
    sname varchar(20),
   age int,
   idcard varchar(18) unique
)charset=utf8; 


方式二:在創(chuàng)建表的同時(shí),添加唯一約束,但是添加方式不同。
  "只有這種添加主鍵的方式,可以添加聯(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)插入相同的值,會(huì)報(bào)錯(cuò)。
insert into student(sname,age,idcard) values ("李四",18,"123456");
insert into student(sname,age,idcard) values ("王五",22,"123456");

刪除唯一約束

刪除唯一約束,使用的語(yǔ)句有點(diǎn)不同。
alter table student drop key idcard;

添加非空約束(not null)

添加非空約束

非空約束指的是我們給某個(gè)字段設(shè)置了非空約束后,當(dāng)我們給該字段插入空值的時(shí)候,會(huì)報(bào)錯(cuò)。添加非空約束,有以下2種方式:

方式一:創(chuàng)建表的時(shí)候,給字段添加非空約束。 
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)

  1. 字段設(shè)置了非空約束后,你不能插入null值。
  2. 字段設(shè)置了非空約束后,不但不能插入null值,而且還不能不插入值
"這些細(xì)節(jié)知識(shí),有時(shí)候是我們沒(méi)有注意到的,因此單獨(dú)拿出來(lái)說(shuō)明。"
一:字段設(shè)置了非空約束后,你不能插入null值。
-- 下面這樣插入會(huì)報(bào)錯(cuò)。
insert into student(sname,age) values (null,22);

二:字段設(shè)置了非空約束后,不但不能插入null值,而且還不能不插入值。
-- 下面這樣插入也會(huì)報(bào)錯(cuò)。
insert into student(age,idcard) values (33,"123456789");

舉例如下:

添加默認(rèn)值約束(default)

某個(gè)字段當(dāng)被設(shè)置了 默認(rèn)值 以后,當(dāng)我們不為該字段指定值的時(shí)候,就會(huì)顯示這個(gè)默認(rèn)值。

添加默認(rèn)值約束

方式一:創(chuàng)建表的時(shí)候,給字段添加默認(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;

引用完整性(參照完整性)

什么是引用完整性?

引用完整性指的是,一張表中字段的取值,需要參照另一張表中某個(gè)字段的取值。這里涉及到的就是 外鍵 : foreign key 。一般情況下,本表中的這個(gè)字段設(shè)置的是外鍵 foreign key ,參考表中的那個(gè)字段的取值,就需要設(shè)置為那個(gè)表的主鍵。

參考下圖幫助理解:

特別注意:學(xué)生表中的 cid 參考的是班級(jí)表中的 cid ,可以看到,這里的字段名是完全一樣的。但是,實(shí)際上,這兩個(gè)字段名可以不一樣,但是這兩個(gè)字段的數(shù)據(jù)類型必須是一樣的

構(gòu)成引用完整性的條件:

  1. 一張表(參照表)中的某個(gè)字段,參照另一張表(被參照表)中的字段(字段名可以不同)。
  2. 兩張表中的字段名可以不同,但是字段的數(shù)據(jù)類型必須一致。
  3. 參照表中的字段在該表中是 foreign key 。被參照表中的字段在該表中是 primary key 。

添加外鍵約束(foreign key)

需要記住一句話:先有被引用的表,然后才可以給當(dāng)前表添加外鍵約束,否則,你引用誰(shuí)去?

添加外鍵約束,有以下2種方式:

方式一:創(chuàng)建表的時(shí)候,給字段添加外鍵約束。 
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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MySQL非空約束(not null)案例講解
  • MySQL外鍵約束(FOREIGN KEY)案例講解
  • MySQL 外鍵約束和表關(guān)系相關(guān)總結(jié)
  • MySQL 8.0新特性 — 檢查性約束的使用簡(jiǎn)介
  • MySQL中外鍵的創(chuàng)建、約束以及刪除
  • Mysql中索引和約束的示例語(yǔ)句
  • MySQL外鍵約束的實(shí)例講解
  • 詳解MySQL 外鍵約束
  • mysql完整性約束實(shí)例詳解
  • MySQL約束超詳解

標(biāo)簽:南充 迪慶 自貢 徐州 麗水 龍巖 無(wú)錫 西寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL完整性約束的定義與實(shí)例教程》,本文關(guān)鍵詞  MySQL,完整性,約束,的,定義,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL完整性約束的定義與實(shí)例教程》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL完整性約束的定義與實(shí)例教程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    香港 | 大姚县| 湟源县| 绥滨县| 丹东市| 新营市| 台中市| 宁强县| 会泽县| 锡林郭勒盟| 闵行区| 丹巴县| 克山县| 金川县| 西乌珠穆沁旗| 安吉县| 京山县| 若羌县| 清原| 阿拉善左旗| 中方县| 稷山县| 北辰区| 余江县| 江永县| 义马市| 电白县| 郎溪县| 闵行区| 英吉沙县| 绵竹市| 长垣县| 天祝| 兴仁县| 长泰县| 白银市| 资溪县| 贞丰县| 山西省| 诸城市| 拉孜县|