У меня есть домашнее задание, где я должен выбрать данные из двух таблиц (книга и автор).Книги имеют двух авторов, и мне нужно отобразить результат с названием книги и авторами, разделенными запятой.
Я пробовал сам, но получил ошибки.
Схема SQL:
CREATE TABLE IF NOT EXISTS `author` (
`id` INT NOT NULL AUTO_INCREMENT,
`name` VARCHAR(128),
`surname` VARCHAR(128),
PRIMARY KEY (`id`)
) DEFAULT CHARSET=utf8mb4 ENGINE=InnoDB;
CREATE TABLE IF NOT EXISTS `book` (
`id` INT NOT NULL AUTO_INCREMENT,
`title` VARCHAR(128),
`author_id` INT NOT NULL,
`author_id_2` INT NOT NULL,
PRIMARY KEY (`id`)
) DEFAULT CHARSET=utf8mb4 ENGINE=InnoDB;
Запрос SQL:
INSERT INTO `author` (`name`, `surname`) VALUES ("William", "Shakespeare");
INSERT INTO `author` (`name`, `surname`) VALUES ("Agatha", "Christie");
INSERT INTO `author` (`name`, `surname`) VALUES ("J. K", "Rowling");
INSERT INTO `author` (`name`, `surname`) VALUES ("George", "Orwell");
INSERT INTO `book` (`title`, `author_id`, `author_id_2`) VALUES ("Hamlet", 1, 2);
INSERT INTO `book` (`title`, `author_id`, `author_id_2`) VALUES ("Macbeth", 1, 3);
INSERT INTO `book` (`title`, `author_id`, `author_id_2`) VALUES ("Murder on the Orient Express", 2, 3);
INSERT INTO `book` (`title`, `author_id`, `author_id_2`) VALUES ("The Secret of Chimneys", 2, 1);
INSERT INTO `book` (`title`, `author_id`, `author_id_2`) VALUES ("1984", 3, 1);
INSERT INTO `book` (`title`, `author_id`, `author_id_2`) VALUES ("Animal Farm", 3, 2);
Запрос:
SELECT
b.title Pavadinimas,
concat(concat(a1.name, ' ', a1.surname), ', ', concat(a2.name, ' ', a2.surname) Autoriai
FROM book b
INNER JOIN author a1 WHERE book.author_id=a1.id
INNER JOIN author a2 WHERE book.author_id_2=a2.id;
Результат должен быть:
Hamlet | William Shakespeare, Agatha Christie