У меня есть таблица, первичный ключ которой упоминается в нескольких других таблицах как внешний ключ. Например:
CREATE TABLE `X` (
`X_id` int NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
PRIMARY KEY (`X_id`)
)
CREATE TABLE `Y` (
`Y_id` int(11) NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`X_id` int DEFAULT NULL,
PRIMARY KEY (`Y_id`),
CONSTRAINT `Y_X` FOREIGN KEY (`X_id`) REFERENCES `X` (`X_id`)
)
CREATE TABLE `Z` (
`Z_id` int(11) NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`X_id` int DEFAULT NULL,
PRIMARY KEY (`Z_id`),
CONSTRAINT `Z_X` FOREIGN KEY (`X_id`) REFERENCES `X` (`X_id`)
)
Теперь я не знаю, сколько таблиц в базе данных содержит внешние ключи в X, как таблицы Y и Z. Есть ли SQL-запрос, который я могу использовать для возврата:
- Список таблиц с внешними ключами в X
- И какая из этих таблиц действительно имеет значения во внешнем ключе