15

我正在尝试在我的 MySQL 数据库中创建多对多关系。我有三个表 FilmsGenresFilms_Genres。我正在使用以下代码来设置它们:

CREATE TABLE Films
(  
    id INT NOT NULL AUTO_INCREMENT,
    PRIMARY KEY(id),   
    Title VARCHAR(255)
),  

CREATE TABLE Genres
(  
    id INT NOT NULL AUTO_INCREMENT,   
    PRIMARY KEY(id),  
    Name VARCHAR(255)
),

CREATE TABLE Films_Genres
(
    film_id INT NOT NULL,  
    genre_id INT NOT NULL,  
    PRIMARY KEY (film_id, genre_id),  
    FOREIGN KEY (film_id) REFERENCES Films(id) ON UPDATE CASCADE,  
    FOREIGN KEY (genre_id) REFERENCES Genres(id) ON UPDATE CASCADE
)  

但是,当我尝试将一些值插入到表中时:

INSERT INTO Films (Title) VALUES ('$title')
INSERT INTO Genres (Name) VALUES ('$genre')

我可以看到表格中的新电影和Films表格中的新流派,GenresFilms_Genres表格没有更新 - 没有新行(我正在通过 phpMyAdmin 检查)。

我究竟做错了什么?

4

3 回答 3

16

Films_Genres除非您在其中明确插入某些内容,否则您不会在表格中看到任何内容。通过 PK 和 FK 实现的参照完整性不适用于为您填充表。

您用于在 中插入新记录的 MySql 代码Films_Genres,如果它是对应于新类型的新电影,可能看起来像

INSERT INTO Films (Title) VALUES ('Title1');
SET @film_id = LAST_INSERT_ID();

INSERT INTO Genres (Name) VALUES ('Genre1');
SET @genre_id = LAST_INSERT_ID();

INSERT INTO Films_Genres (film_id, genre_id) VALUES(@film_id, @genre_id);

在 php 端获取一个新分配的 id 用于自动增量字段使用$mysqli->insert_id

现在,如果您想创建一部新电影并一次将其分配给多种类型,您可以这样做

INSERT INTO Films (Title) VALUES ('Title2');
SET @film_id = LAST_INSERT_ID();
-- if you get ids of genre from your UI just use them
INSERT INTO Films_Genres (film_id, genre_id) 
SELECT @film_id, id
  FROM Genres
 WHERE id IN (2, 3, 4);

INSERT INTO Films (Title) VALUES ('Title3');
SET @film_id = LAST_INSERT_ID();
-- if you names of genres you can use them too
INSERT INTO Films_Genres (film_id, genre_id) 
SELECT @film_id, id
  FROM Genres
 WHERE Name IN ('Genre2', 'Genre4');

这是SQLFiddle演示

于 2013-07-03T23:36:04.560 回答
1

你必须自己填写多对多表,这就是mysql的工作原理,不幸的是这里没有自动猜测工作。

于 2013-07-03T23:44:02.903 回答
0

基本上,您还应该在链接表中插入一行以“链接”您刚刚插入的电影和类型。Mysql 引擎不会自动为您执行此操作(它根本不知道这两条记录应该以某种方式相关) - 这将在应用程序端或手动完成

INSERT INTO Films_Genres (film_id,genre_id) VALUES (1,1)
于 2013-07-03T23:38:42.403 回答