【跟着例子学MySQL】多表关联 -- 一对多关系
warning:
这篇文章距离上次修改已过190天,其中的内容可能已经有所变动。
-- 创建一对多关系的示例
-- 创建出版社表
CREATE TABLE publisher (
publisher_id INT NOT NULL AUTO_INCREMENT,
name VARCHAR(100) NOT NULL,
PRIMARY KEY (publisher_id)
);
-- 创建作者表,一个作者可以属于多个出版社
CREATE TABLE author (
author_id INT NOT NULL AUTO_INCREMENT,
name VARCHAR(100) NOT NULL,
publisher_id INT NOT NULL,
PRIMARY KEY (author_id),
FOREIGN KEY (publisher_id) REFERENCES publisher(publisher_id)
);
-- 插入数据
INSERT INTO publisher (name) VALUES ('Publisher A'), ('Publisher B'), ('Publisher C');
INSERT INTO author (name, publisher_id) VALUES
('Author 1', 1),
('Author 2', 1),
('Author 3', 2),
('Author 4', 3);
-- 查询作者及其所在出版社
SELECT a.name AS author_name, p.name AS publisher_name
FROM author a
JOIN publisher p ON a.publisher_id = p.publisher_id;
这个示例展示了如何创建两个表,一个出版社表和一个作者表,并如何通过外键建立它们之间的一对多关系。然后,我们插入了一些数据,并提供了一个查询来展示作者及其所在出版社的名称。这个例子简单但有效地展示了数据库设计中一对多关系的应用。
评论已关闭