成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > MySQL完整性約束的定義與實例教程

MySQL完整性約束的定義與實例教程

熱門標簽:400電話變更申請 400電話辦理服務價格最實惠 大豐地圖標注app 催天下外呼系統(tǒng) 北京金倫外呼系統(tǒng) html地圖標注并導航 呂梁外呼系統(tǒng) 南太平洋地圖標注 武漢電銷機器人電話

完整性約束

完整性約束的定義

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

完整性約束的分類

實體完整性:記錄之間不能重復。

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

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

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

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

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

主鍵約束(primary key)

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

添加主鍵約束,有以下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)建表的同時,添加主鍵約束,但是添加方式不同。
  "只有這種添加主鍵的方式,可以添加聯合主鍵"
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是給約束起一個名字;

單個主鍵和聯合主鍵的區(qū)別

"單個主鍵"
    將表中某一個字段設置為主鍵,用這一個字段,來唯一確定一條記錄。
    只要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

主鍵字段的挑選原則

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

特別注意:當一個建表語句中,某個字段只有primary key限制,而沒有使用主鍵自增 auto_increament
需要我們自己給主鍵字段插入值,否則會出現如下錯誤。 "ERROR 1364 (HY000): Field 'sid' doesn't have a default value"

但是我們上面說過,主鍵字段一般是不進行修改的,也就是說不要主動給他值,主鍵字段應該是讓系
統(tǒng)默認賦值。這個在學習過 主鍵自增 后你就明白了。

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

舉例說明:

刪除主鍵約束

alter table student drop primary key;


主鍵自增(auto_increment)

主鍵自增的含義和特點

見名知意,這個是用來 幫助主鍵自動添加值 的一個約束。上面我們說過,主鍵字段最好不要有任何改動,當然也包括給主鍵字段插入數值的時候,也不要手動去添加主鍵,而是讓系統(tǒng)自動給主鍵字段進行賦值。主鍵自增有如下2個特點:

  1. 設置了主鍵自增后,主鍵值會從1開始,每次自增1。
  2. 以前用過的主鍵值,當你刪除該行記錄后,主鍵值仍然是一個新的值,并不會重復使用以前出現過的主鍵值。

對第二個特點的說明:

添加唯一約束,有以下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配合使用,插入數據的時候,
-- 不需要給主鍵字段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)

唯一性約束的含義

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

添加唯一約束,有以下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)建表的同時,添加唯一約束,但是添加方式不同。
  "只有這種添加主鍵的方式,可以添加聯合主鍵"
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);

-- 設置了唯一約束的字段,當插入相同的值,會報錯。
insert into student(sname,age,idcard) values ("李四",18,"123456");
insert into student(sname,age,idcard) values ("王五",22,"123456");

刪除唯一約束

刪除唯一約束,使用的語句有點不同。
alter table student drop key idcard;

添加非空約束(not null)

添加非空約束

非空約束指的是我們給某個字段設置了非空約束后,當我們給該字段插入空值的時候,會報錯。添加非空約束,有以下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;

字段添加非空約束后具有如下特點

  1. 字段設置了非空約束后,你不能插入null值。
  2. 字段設置了非空約束后,不但不能插入null值,而且還不能不插入值
"這些細節(jié)知識,有時候是我們沒有注意到的,因此單獨拿出來說明。"
一:字段設置了非空約束后,你不能插入null值。
-- 下面這樣插入會報錯。
insert into student(sname,age) values (null,22);

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

舉例如下:

添加默認值約束(default)

某個字段當被設置了 默認值 以后,當我們不為該字段指定值的時候,就會顯示這個默認值。

添加默認值約束

方式一:創(chuàng)建表的時候,給字段添加默認值。 
create table student(
   sid int primary key auto_increment,
   sname varchar(20),
   age int default 0,
   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添加默認值的代碼有點特別。
alter table student alter age set default 0;

刪除默認值

alter table student alter column age drop default;

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

什么是引用完整性?

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

參考下圖幫助理解:

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

構成引用完整性的條件:

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

添加外鍵約束(foreign key)

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

添加外鍵約束,有以下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相當于起的別名。"

總結

到此這篇關于MySQL完整性約束的文章就介紹到這了,更多相關MySQL完整性約束內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

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

標簽:南充 迪慶 自貢 徐州 麗水 龍巖 無錫 西寧

巨人網絡通訊聲明:本文標題《MySQL完整性約束的定義與實例教程》,本文關鍵詞  MySQL,完整性,約束,的,定義,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL完整性約束的定義與實例教程》相關的同類信息!
  • 本頁收集關于MySQL完整性約束的定義與實例教程的相關信息資訊供網民參考!
  • 推薦文章
    中文一区一区三区高中清不卡| 蜜桃传媒一区二区亚洲| 国产极品在线播放| 最近2019年中文视频免费在线观看| 亚洲狠狠婷婷综合久久久久图片| 天堂在线免费观看视频| 激情久久久久| 亚洲成人在线视频播放| 国产伦精品一区二区三区精品视频| 亚洲视频精品在线| 欧美日韩小视频| 网上成人av| 99精品电影| 久久免费的精品国产v∧| 亚洲无码久久久久| 天堂网.www在线资源| 色嗨嗨av一区二区三区| 香港日本三级视频| 久久久国产欧美| 奇米影视第四狠狠777| 国产精品久久久久久久久久久新郎| 精品少妇人妻av免费久久洗澡| 免费成人美女在线观看.| 欧美bbbxxxxx| 亚洲精品1区| 欧洲黄色一级视频| 日韩精品一区二区三区高清免费| 成人在线观看av| 美腿丝袜亚洲图片| a级片在线观看免费| 不卡影院免费观看| 国产手机精品在线| 波多野结衣电影在线播放| 一区二区三区亚洲变态调教大结局| 四虎影成人精品a片| 亚洲欧洲一区二区三区在线观看| 欧美精品一区二区三区视频| av手机免费观看| 黄色手机在线视频| 国产美女诱惑一区二区| 欧美爱爱视频网站| 色综合天天综合网国产成人综合天| 91精品视频在线免费观看| 国产.精品.日韩.另类.中文.在线.播放| 日韩欧美福利视频| 久久亚洲精品无码va白人极品| 性生活免费观看视频| 久久色视频免费观看| 性生活免费观看视频| 成年女人毛片| 在线国产网址| 激情综合网av| 99热免费精品在线观看| 日韩欧美一级视频| 嫩草影院官网| 伊人国产视频| 国产xxxxx视频| 日韩一区二区精品视频| 色婷婷综合网站| 成年免费视频黄网站在线观看| 影音先锋中文在线视频| 四虎4hu新地址入口2023| 9.1在线观看免费| 先锋在线资源一区二区三区| 手机视频在线观看| 久久精品日产第一区二区三区精品版| 另类free性欧美护士| 欧美精品久久久久久久久久丰满| 欧美日韩午夜在线视频| 亚洲AV无码成人精品区明星换面| 在线观看91久久久久久| 97超级在线观看免费高清完整版电视剧| 乱精品一区字幕二区| 免费成人在线观看| а√中文在线天堂精品| 国产传媒免费在线观看| 电影久久久久久| 极品白嫩丰满美女无套| 欧美男男tv网站在线播放| 国产极品在线播放| 乱人伦视频在线| 色偷偷免费视频| 女人抽搐喷水高潮国产精品| 在线视频这里只有精品| 最新亚洲伊人网| 日本久久久久久久久久久久| 国产欧美综合在线观看第十页| 欧美日韩国产成人高清视频| 日本韩国精品在线| 91香蕉国产视频| 免费日韩一级片| 99精品热视频只有精品10| 免费一区二区三区在线观看| 91福利免费观看| 国产亚洲一区二区三区| 日韩影片在线观看| 欧美夫妻性生活视频| 欧美高清www午色夜在线视频| 精品三级av在线导航| xxxx.欧美| 亚洲第一会所| 手机在线免费av| 国产精品污www一区二区三区| 99精品全国免费观看| 久久在精品线影院精品国产| 亚洲欧美国产精品桃花| 欧美成人69av| 老头老太做爰xxx视频| 成人av在线资源| 黄色小视频在线看| 91桃色在线| 久久免费视频2| 亚洲国产一区在线观看| 亚洲影院天堂中文av色| 天美av一区二区三区久久| 国产性做久久久久久| 亚洲精品美女久久| 欧美资源一区| 91精品视频免费观看| 成人av在线资源网| 福利视频一区二区三区四区| 色先锋久久av资源部| 久久精品视频在线播放| 亚洲一级二级| 日韩欧美精品一区二区| 国产精品777777在线播放| 搡的我好爽在线观看免费视频| 亚洲最大在线| 欧美日韩国产成人高清视频| 18免费在线视频| 91免费精品国偷自产在线| 日韩美女在线观看| 国产欧洲精品视频| 久热视线观看免费视频| 国产视频1区2区3区| 4444亚洲人成无码网在线观看| 午夜成人在线视频| 国产麻豆麻豆| 欧洲一区二区日韩在线视频观看免费| 污视频网站观看| 尤物视频免费观看| 国产精品久久久久久久久久辛辛| 国产一级片免费视频| av在线播放中文字幕| 成视频年人免费看黄网站| 中文字幕一区免费在线观看| 成人高清免费在线| 欧美美女一区二区在线观看| 欧美图片第一页| 最新成人av网站| 91精品国产66| 中国黄色a级片| 91精品国产欧美一区二区| 日韩成人免费电影| 日韩av地址| 久久超级碰视频| 女人被狂躁到高潮的免费| 精品国产免费观看| 精品一区二区三区在线成人| 亚洲永久精品国产| 91福利电影| 国产不卡在线视频| 性生交生活影碟片| 中文字幕网站在线观看| 日韩写真福利视频在线| 美洲天堂一区二卡三卡四卡视频| 国产精品久久久久久久久久久免费看| 亚洲精品一区二区三区在线观看| 国产三级精品三级| 白嫩少妇丰满一区二区| 国产深喉视频一区二区| 欧美日韩va| 波多野结衣的一区二区三区| 日韩成人av电影| 亚洲高清不卡av| 神马午夜电影一区二区三区在线观看| 99国产超薄肉色丝袜交足的后果| 懂色av中文一区二区三区| 色影院视频在线| free性欧美| www.av天天| 午夜影院免费在线观看| 99久久精品无码一区二区毛片| 久久亚洲免费视频| 日本一区二区不卡在线| 99中文字幕在线| 凹凸成人在线| 青青青草网站免费视频在线观看| 亚洲少妇激情视频| 日韩激情毛片| 国产高清在线观看| 国产精品白浆一区二小说| 欧美日韩性视频在线| 久久亚洲精品国产亚洲老地址| 日av在线播放中文不卡| 亚洲午夜网未来影院| 男人的天堂久久精品| 国产裸体无遮挡| 日本中文字幕一区二区有码在线| 国产性生活大片| 热99这里只有精品| 日本韩国精品一区二区在线观看| 成人免费视频网站在线观看| 五月天色婷婷丁香| 久久久久久久久久久久久国产精品| 天堂在线精品| 99久久婷婷国产| 国精产品一区二区三区有限公司| 国产成人a人亚洲精品无码| 国产精品免费久久久久影院| 亚洲精品一区二区三区樱花| 在线人成日本视频| 国产精品美女一区二区三区四区| 国产日韩欧美夫妻视频在线观看| 少妇免费视频| 中文字幕第8页| 欧美精品成人在线| 在线观看视频一区二区欧美日韩| 日韩欧美亚洲日产国| 欧美一区二区三区啪啪| 久久精品欧美| 第一av在线| 岛国一区二区三区| 精品欧美日韩精品| 一区二区三区国产好| 日韩在线中文字| 欧美特黄视频| 神马午夜电影一区二区三区在线观看| 寂寞护士中文字幕mp4| 国产精品国产三级国产aⅴ入口| 精品久久毛片| 在线不卡视频| 国产中文字幕二区| 热草久综合在线| 少妇精品久久久一区二区| 国产伦精品一区二区三毛| 日韩在线一区二区| 色婷婷av一区二区三区之红樱桃| 亚洲人成在线播放网站岛国| 中文字幕 自拍| 久热在线视频精品网站| 免费激情视频在线观看| 色综合久久久久久中文网| 国产午夜精品麻豆| 国产精品夜夜夜爽张柏芝| 九色porny丨国产首页在线| 亚洲大香人伊一本线| 欧美精品久久一区二区三区| 白丝美女让我捅| 深田咏美中文字幕| 成人午夜av影视| 亚洲免费黄色网址| 在线免费福利| 一日本道久久久精品国产| 亚洲色图欧美日韩| 国产九九视频一区二区三区| 午夜激情在线| www.xxx麻豆| 高清国产mv在线观看| jizz久久久久久| 成人一区二区三区在线观看| 国产精品综合二区| 欧美自拍偷拍| 亚洲熟女一区二区三区| 亚洲人成啪啪网站| 色一区二区三区| 亚洲国产女人aaa毛片在线| 2021最新国产精品一区| 538任你躁在线精品免费| 成年网站在线观看视频| 污污的网站18| 91麻豆蜜桃一区二区三区| 99久久精品国产观看| 91精品国产91久久久久久最新毛片| 深夜福利视频在线观看| 国产影视一区| 亚洲综合av网| 日韩在线第一区| 狠狠色伊人亚洲综合网站色| 日韩欧美高清在线| 天天做天天摸天天爽天天爱| 日本午夜精品视频| 日本爱爱爱视频| 极品国产人妖chinesets亚洲人妖| 亚洲综合日韩在线| 色婷婷综合久久久久中文字幕| 久久亚洲av午夜福利精品一区| 国产最顶级的黄色片在线免费观看| 9色国产精品| 欧美熟妇激情一区二区三区| 亚洲欧洲一区二区在线播放| 亚洲成熟丰满熟妇高潮xxxxx| av成人免费在线观看| 中文字幕在线观看视频免费| 日韩一区二区三区四区| 亚洲精品中文字幕乱码三区不卡| 国产一区二区三区四区老人| 人妻一区二区三区| 可以免费看av的网址| 欧美日韩电影一区| 国产亚洲精品久久久久久777| 日韩视频免费观看高清| 亚洲欧美综合在线精品| 国产香蕉视频在线看| 亚洲精品在线观看91| 小说区图片区图片区另类灬| 午夜性色福利视频| 第四色在线一区二区| 四虎精品永久在线| aa一级黄色片| 爱情岛论坛亚洲品质自拍视频网站| 久久久久狠狠高潮亚洲精品| 日皮视频免费观看| 白白操在线视频| 欧美视频精品在线| 国产无遮挡免费视频| 日本一区二区免费电影| 在线观看一二三区| 久久电影网站| 亚洲av成人无码久久精品| 日韩国产精品久久久| 精品动漫一区| 欧美激情国产在线| 91久久久在线| 亚洲福利在线观看视频| 国产精品久久久久久久第一福利| 国产精品毛片一区二区| 国产美女久久|