Список ограничений из базы данных MySQL - PullRequest
75 голосов
/ 11 июня 2010

Как получить список всех ограничений из конкретной базы данных?

Ответы [ 4 ]

119 голосов
/ 11 июня 2010

Используйте таблицу information_schema.table_constraints, чтобы получить имена ограничений, определенных для каждой таблицы:

select *
from information_schema.table_constraints
where constraint_schema = 'YOUR_DB'

Используйте таблицу information_schema.key_column_usage, чтобы получитьполя в каждом из этих ограничений:

select *
from information_schema.key_column_usage
where constraint_schema = 'YOUR_DB'

Если вместо этого вы говорите об ограничениях внешнего ключа, используйте information_schema.referential_constraints:

select *
from information_schema.referential_constraints
where constraint_schema = 'YOUR_DB'
20 голосов
/ 26 сентября 2012

Отличный ответ от @ Senseful.

Я представляю измененный запрос для тех, кто ищет только список имен ограничений (но не другие данные / столбцы):

SELECT DISTINCT(constraint_name) 
FROM information_schema.table_constraints 
WHERE constraint_schema = 'YOUR_DB' 
ORDER BY constraint_name ASC;
4 голосов
/ 03 марта 2018

Это действительно помогает, если вы хотите увидеть ограничения первичного и внешнего ключа, а также правила вокруг этих ограничений, такие как ON_UPDATE и ON_DELETE, а также имена столбцов и внешних столбцов:

SELECT tc.constraint_schema,tc.constraint_name,tc.table_name,tc.constraint_type,kcu.table_name,kcu.column_name,kcu.referenced_table_name,kcu.referenced_column_name,rc.update_rule,rc.delete_rule

FROM information_schema.table_constraints tc

inner JOIN information_schema.key_column_usage kcu
ON tc.constraint_catalog = kcu.constraint_catalog
AND tc.constraint_schema = kcu.constraint_schema
AND tc.constraint_name = kcu.constraint_name
AND tc.table_name = kcu.table_name

LEFT JOIN information_schema.referential_constraints rc
ON tc.constraint_catalog = rc.constraint_catalog
AND tc.constraint_schema = rc.constraint_schema
AND tc.constraint_name = rc.constraint_name
AND tc.table_name = rc.table_name

WHERE tc.constraint_schema = 'my_db_name'

Возможно, вы даже захотите добавить дополнительную информацию об этих столбцах, просто добавьте ее в SQL (и выберите нужные столбцы):

LEFT JOIN information_schema.COLUMNS c
ON kcu.constraint_schema = c.table_schema
AND kcu.table_name = c.table_name
AND kcu.column_name = c.column_name
0 голосов
/ 31 мая 2016

SELECT * FROM USER_CONSTRAINTS WHERE TABLE_NAME = "tabnam";

...