查找表之间的外键约束列信息
Find Foreign Key Constraint Column Information Between Tables
Table A 对 Table B (id) 有一个外键约束(类型)。但是,type 不为空且 id 可为空。
我正在尝试使用 information_schema 构建一个查询,该查询将查看外键约束并匹配列类型和可为空的列以查看它们是否同步,但是我在逻辑上遇到了问题.
select kcu.table_name, kcu.column_name, c.column_type, c.is_nullable,kcu.referenced_table_name, kcu.referenced_column_name,c.column_type, c.is_nullable
from key_column_usage kcu
inner join columns c on c.table_schema=kcu.table_schema and c.column_name=kcu.column_name and c.table_name=kcu.table_name
where kcu.referenced_table_name='Table_B' and kcu.table_name='Table_A';
我知道这个语法是不正确的——这就是我到目前为止所能组合的全部内容。我希望能够对数据库中的每个 table 执行此操作,并按 table_name 排序,然后按 column_name 排序。它可以排除 column_type 和 is_nullable 字段相同的列。
外部约束一侧的 NULLABLE 列可能有正当理由,但这将比较所涉及列的 type/nullable 属性。
SELECT
kcu.constraint_schema
, kcu.constraint_name
, kcu.referenced_table_name
, kcu.referenced_column_name
, kcu.table_name
, kcu.column_name
, refcol.column_type referenced_column_type
, childcol.column_type
, refcol.is_nullable referenced_is_nullable
, childcol.is_nullable
FROM information_schema.key_column_usage kcu
INNER JOIN information_schema.columns refcol
ON refcol.table_schema = kcu.referenced_table_schema
AND refcol.table_name = kcu.referenced_table_name
AND refcol.column_name = kcu.referenced_column_name
INNER JOIN information_schema.columns childcol
ON childcol.table_schema = kcu.table_schema
AND childcol.table_name = kcu.table_name
AND childcol.column_name = kcu.column_name
WHERE (
refcol.is_nullable <> childcol.is_nullable
OR
refcol.column_type <> childcol.column_type
)
AND kcu.TABLE_SCHEMA = 'rextester' #change this value to suit
ORDER BY
kcu.table_name
, kcu.column_name
;
Table A 对 Table B (id) 有一个外键约束(类型)。但是,type 不为空且 id 可为空。
我正在尝试使用 information_schema 构建一个查询,该查询将查看外键约束并匹配列类型和可为空的列以查看它们是否同步,但是我在逻辑上遇到了问题.
select kcu.table_name, kcu.column_name, c.column_type, c.is_nullable,kcu.referenced_table_name, kcu.referenced_column_name,c.column_type, c.is_nullable
from key_column_usage kcu
inner join columns c on c.table_schema=kcu.table_schema and c.column_name=kcu.column_name and c.table_name=kcu.table_name
where kcu.referenced_table_name='Table_B' and kcu.table_name='Table_A';
我知道这个语法是不正确的——这就是我到目前为止所能组合的全部内容。我希望能够对数据库中的每个 table 执行此操作,并按 table_name 排序,然后按 column_name 排序。它可以排除 column_type 和 is_nullable 字段相同的列。
外部约束一侧的 NULLABLE 列可能有正当理由,但这将比较所涉及列的 type/nullable 属性。
SELECT
kcu.constraint_schema
, kcu.constraint_name
, kcu.referenced_table_name
, kcu.referenced_column_name
, kcu.table_name
, kcu.column_name
, refcol.column_type referenced_column_type
, childcol.column_type
, refcol.is_nullable referenced_is_nullable
, childcol.is_nullable
FROM information_schema.key_column_usage kcu
INNER JOIN information_schema.columns refcol
ON refcol.table_schema = kcu.referenced_table_schema
AND refcol.table_name = kcu.referenced_table_name
AND refcol.column_name = kcu.referenced_column_name
INNER JOIN information_schema.columns childcol
ON childcol.table_schema = kcu.table_schema
AND childcol.table_name = kcu.table_name
AND childcol.column_name = kcu.column_name
WHERE (
refcol.is_nullable <> childcol.is_nullable
OR
refcol.column_type <> childcol.column_type
)
AND kcu.TABLE_SCHEMA = 'rextester' #change this value to suit
ORDER BY
kcu.table_name
, kcu.column_name
;