亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

更多QQ空间微信QQ好友腾讯朋友复制链接
您的位置:首頁/技術文章
文章詳情頁

mysql外鍵基本功能與用法詳解

【字号: 作者:豬豬瀏覽:30日期:2023-10-15 15:16:36

本文實例講述了mysql外鍵基本功能與用法。分享給大家供大家參考,具體如下:

本文內容: 什么是外鍵 外鍵的增加 外鍵的修改和刪除 外鍵的約束模式

首發日期:2018-04-12

什么是外鍵: 外鍵就是表中存在一個字段指向另外一個表的主鍵,那么這個字段就可以稱為外鍵。 一張表可以有多個外鍵。 外鍵用于約束表與表之間的關系,可以說外鍵是表之間的映射關系,這個關系可以幫助我們處理表之間關系的緊密性和存在性(比如學生表的cid班級號與班級表的id建立關聯,cid應該不能為不存在的,如果不增加外鍵cid,沒有建立上關系,我們就不知道班級號不存在。)。 或者說,外鍵是告訴數據庫系統,我們所認為的關系,單純的數據,系統是不知道實際意義的,外鍵就是告訴系統應該如何處理他們的關系。 所以,外鍵的核心是約束。外鍵的增加: 創建外鍵的前提是該字段首先是一個索引,如果不是的話,創建外鍵是會創建成一個普通索引【所以可以不在意】。 創建外鍵的另外一個前提是“指向表”已經創建,對于一個不存在的表,將無法使用外鍵對應上。 增加的方式: 1.在創建表的時候定義,在所有字段定義結束后使用foreign key(外鍵字段) references 指向表(主鍵)來 定義,比如mysql外鍵基本功能與用法詳解 2.也可以修改字段來增加: alter table 表名 add [constraint 外鍵名字] foreign key(外鍵字段) references 父表(主鍵字段); constraint 外鍵名字:可以幫助定義外鍵的名字,但不建議使用,因為要求外鍵名都唯一,而使用系統自定義的絕對不會重復,

create table student(id int primary key auto_increment,name varchar(15) not null,gender varchar(10) not null,cid int,foreign key(cid) references class(id));

create table class(id int primary key auto_increment,cname varchar(15));補充: 在Mysql中,如果存儲引擎不是innodb,那么無法使外鍵的約束作用生效,即使是能成功增加外鍵。 外鍵名不能重復,所以不建議使用constraint 外鍵名字外鍵的修改與刪除: 修改:不能修改外鍵信息,如外鍵指向之類的,只能先刪除再新增。 刪除語法:alter table 表名 drop foreign key 外鍵名; 這里的外鍵名不是外鍵字段,而是外鍵名。如果沒有使用constraint來定義,可以通過show create來查看表創建語句中系統定義的外鍵名。 mysql外鍵基本功能與用法詳解 補充: 刪除外鍵時,如果使用desc會看到表結構還有MUL,那是一個索引。因為創建外鍵時,字段會被創建成一個索引。如果不想保留,可以使用drop index 字段名 on 表名.外鍵的約束模式: 外鍵是用來約束表之間的關系的。 (約定創建外鍵的表稱為子表,指向的表稱為父表) 針對子表:可以約束子表的插入和修改【這種約束是父表對子表的約束】 涉及到外鍵的插入和修改時,如果外鍵字段找不到對應的匹配那么會插入修改失敗(像插入選課記錄不可能插入一門課程表中沒有的課程)。 比如:mysql外鍵基本功能與用法詳解 針對父表:可以約束父表的刪除和更新,通常有可以以下幾種約束模式。【這種約束是子表對父表的約束】 模式: strict嚴格模式:涉及到外鍵的刪除和更新時,如果對應記錄的主鍵數據已經被子表使用時,那么無法刪除(像已經有人入學了某個班級,學校不可能犯傻去把某個班級刪除,只能刪除那些沒人入學的班級。)cascade級聯模式:涉及到外鍵的刪除和更新時,如果字段已經被子表使用,子表中的數據會對應更新(像某個班改了班號,那么學生表中的班別都對應更改;如果某個班被刪除,就刪除對應班的所有學生)set null置空模式:涉及到外鍵的刪除和更新時,如果字段已經被子表使用,那么子表中的外鍵數據會置空(像某個班被刪掉了,不應該刪掉所有學生,而是應該給他們先置空再重新分配班別)【子表允許置空的前提是該字段允許為空】 其實可以給不同操作指定不同模式 綜上所述(根據我的那些舉例),實際上,合適的舉措是刪除時置空(即使某個班太垃圾了,想刪除某個班,但也不應該將所有學生退學,而是將它們分到別的班),修改時級聯(允許更改班號,而且更改會更新到學生中) 不同操作設置不同模式的設置方法(在子表中操作):foreign key(外鍵字段) references 父表(主鍵) on 操作 模式

foreign key(外鍵字段) references 父表 (主鍵) on delete set null on update cascade;

-- 實驗表結構create table class(id int primary key auto_increment,cname varchar(15));create table student2(id int primary key auto_increment,name varchar(15) not null,gender varchar(10) not null,cid int,foreign key(cid) references class(id) on delete set null on update cascade);-- 實驗表數據:insert into class(cname) values('python'),('linux'),('java'),('html5');insert into student2(name,gender,cid) values('Alice','female',1);insert into student2(name,gender,cid) values('John','female',2);insert into student2(name,gender,cid) values('Jack','female',3);insert into student2(name,gender,cid) values('Amy','female',4);select * from student2;select * from class;-- 嘗試更新級聯update class set id = 6 where cname='python';select * from student2; -- 結果原來的python的cid=6-- 嘗試刪除置空delete from class where cname='java';select * from student2; -- 結果原來的java的cid=null 補充: 需要設置好約束模式,不要在多個子表中使用不同的約束模式,不然會沖突。

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數大匯總》、《MySQL日志操作技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》及《MySQL數據庫鎖相關技巧匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 欧美日韩一区二区三 | 久青草视频免费视频播放线路1 | 肉色呻吟胯下丝袜高跟视频 | 日韩福利视频一区 | 91精品一区二区三区在线观看 | 欧美一区二区三区不卡视频 | 九九九热精品 | 精品国产3p一区二区三区 | 国产情侣自拍在线 | 日韩一区二区免费视频 | 成人在激情在线视频 | 亚洲欧美韩国日产综合在线 | 青青草社区 | 亚州一区二区 | 国亚洲欧美日韩精品 | 在线观看国产麻豆 | 欧美人体一区二区三区 | 成人午夜在线观看 | 亚洲精品一区二区三区第四页 | 国产在线精品99一卡2卡 | 欧美三级成版人版在线观看 | 国产精品日韩一区二区三区 | 特级xxxxx欧美孕妇孕交 | 国产乱码一区二区三区四 | 免费国产成人 | 精品哟啊呦v视频在线观看 精品哟哟国产在线观看 | 国产成人www免费人成看片 | a级毛片免费看 | 在线观看视频一区 | 国产成人精品免费视频大全五级 | 日韩黄色一级 | 久久久久无码国产精品一区 | 91日韩视频 | 亚洲三级一区 | 亚洲黄色在线 | 国产人成精品香港三级在 | 国产亚洲精品一区二区三区 | 成人a大片高清在线观看 | 亚洲夜色综合久久 | 91高清在线成人免费观看 | 视频二区肥岳精品推荐 |