Я пытаюсь удалить внешний ключ из таблицы, ссылающейся на указанную таблицу. Я не знаю названия внешнего ключа, я знаю только таблицу, в которой он находится, и таблицу, на которую он ссылается. Вот что я получил до сих пор:
alter table tblTableWhereFKIs drop foreign key (select constraint_name
from information_schema.key_column_usage
where referenced_table_name = 'tblReferencedByFK' and table_name = 'tblTableWhereFKIs' limit 1);
Но я получаю ошибку:
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(select constraint_name
from information_schema.key_column_usage
where referen' at line 1
Работает только один:
mysql> select constraint_name
-> from information_schema.key_column_usage
-> where referenced_table_name = 'tblReferencedByFK' and table_name = 'tblTableWhereFKIs' limit 1;
+-----------------------------------------+
| constraint_name |
+-----------------------------------------+
| fk_tblTableWhereFKIs_tblReferencedByFK1 |
+-----------------------------------------+
1 row in set (0.08 sec)