多表關系一對多和多對多


多表關系一對多和多對多

一、一對多

  1. 創建數據

一對多:外鍵必須放在多的一方,此時外鍵值不唯一

# 出版社(publish): id,name,address,phone
create table publish(
	id int primary key auto_increment,
    name varchar(64),
    address varchar(256),
    phone char(20)
);

# 書(book):id,name,price,publish_id, author_id
create table book(
	id int primary key auto_increment,
    name varchar(64) not null,
    price decimal(5, 2) default 0,
    publish_id int,  # 一對多的外鍵不能設置唯一
    foreign key(publish_id) references publish(id)
    on update cascade
    on delete cascade
);
  1. 插入數據關聯表(book)和被關聯表(publish)

增:先增加被關聯表(publish)的數據,再增加關聯表(book)的數據

# 增:先增加被關聯表(publish)的數據,再增加關聯表(book)的數據
mysql>: insert into publish(name, address, phone) values
('人民出版社', '北京', '010-110'),
('西交大出版社', '西安', '010-119'),
('老男孩出版社', '上海', '010-120');

mysql>: insert into book(name, price, publish_id) values
('西游記', 6.66, 1),
('東游記', 8.66, 1),
('python從入門到入土', 2.66, 2),
('輪程序員修養之道', 3.66, 3),
('好好活着', 88.88, 3);

# 沒有被關聯的字段,插入依舊錯誤
mysql>: insert into book(name, price, publish_id) values ('打臉之道', 0.3, 4);  # 失敗
  1. 修改關聯表(book)和被關聯表(publish)
# 更新book:
#直接更新關聯表的(book) 外鍵,修改的值對應被關聯表(publish) 主鍵 如果存在,可以更新成功,反之失敗
mysql>: update book set publish_id=2 where id=4;  # 成功
mysql>: update book set publish_id=1 where id=4;  # 失敗

# 更新publish 
# 直接更新被關聯表的(publish) 主鍵,關聯表(book) 外鍵 會級聯更新
mysql>: update publish set id=10 where id=1;
  1. 刪除關聯表(book)和被關聯表(publish)
# 刪 book
# 刪關聯表,被關聯表不會發生變化
mysql>: delete from book where publish_id = 3;

# 刪 publish
# 刪被關聯表,關聯表會被級聯刪除
mysql>: delete from publish where id = 2;
  1. 補充
# 假設:書與作者也是 一對多 關系,一個作者可以出版多本書
create table book(
	id int primary key auto_increment,
    name varchar(64) not null,
    price decimal(5, 2) default 0,
    publish_id int,  # 一對多的外鍵不能設置唯一
    foreign key(publish_id) references publish(id)
    on update cascade
    on delete cascade
    
    # 建立與作者 一對多 的外鍵關聯
    author_id int,  
    foreign key(author_id) references author(id)
    on update cascade
    on delete cascade
);


二、多對多

多對多:一定要創建第三張表(關系表),每一個外鍵值不唯一,看可以多個外鍵建立聯合唯一

  1. 創建表
# 作者(author):id, name, age
create table author(
	id int primary key auto_increment,
    name varchar(64),
    age int unsigned default 0
);

# 出版社(publish):id, name, address
create table publish(
	id int primary key auto_increment,
    name varchar(64),
    address varchar(256)
);

# 作者與出版社關系表:id, author_id, publish_id
create table author_publish(
	id int primary key auto_increment,
    # 關系表一定有多個外鍵,關聯着多張表
    # 關聯作者表
    author_id int,
    foreign key(author_id) references author(id)
    on update cascade
    on delete cascade,
    # 關聯出版社表
    publish_id int,
    foreign key(publish_id) references publish(id)
    on update cascade
    on delete cascade,
    # 建立兩個字段的聯合唯一
    unique(author_id, publish_id)
);

  1. 對關聯表(author)和被關聯表(publish)

注:關系表 關聯着 作者 和 出版社 兩張表,在表結構上 作者 與 出版社 兩表鍵沒有任何關系

# 增:兩張被關聯表,沒有前后關系,但關系表必須在兩個表都提供數據后才能進行 關系匹配
mysql>: insert into author(name, age) values('ruakei', 67),('engo', 76),('Lxx', 3);
mysql>: insert into publish(name, address) values('python出版社', '上海'),('小女孩出版社', '北京');

mysql>: insert into author_publish(author_id, publish_id) values(1,1),(1,2),(2,1),(2,2),(3,1);

# 操作兩張被關系表:
#		增:不會影響關系表
mysql>: insert into publish(name, address) values('西交大出版社', '西安');
#		改:關系表都會級聯更新
mysql>: update publish set id=10 where id=1;
#		刪:關系表都會級聯刪除
mysql>: delete from author where name='ruakei';

總結: 關系表操作:增、刪、改,只要兩張被關系表有提供對應的操作數據,都可以操作成功,且對兩張被關系表沒有影響


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM