Как запросить описание столбца таблицы? - PullRequest
0 голосов
/ 17 марта 2011

Есть ли запрос, чтобы получить список столбцов со ссылкой на внешний ключ первичного ключа?

SELECT column_name, data_type, CHARacter_maximum_length
FROM DBTIME.information_schema.columns
WHERE table_name = 'Table Name' 

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

Ответы [ 2 ]

0 голосов
/ 17 марта 2011
SELECT
    K_Table = FK.TABLE_NAME,
    FK_Column = CU.COLUMN_NAME,
    PK_Table = PK.TABLE_NAME,
    PK_Column = PT.COLUMN_NAME,
    Constraint_Name = C.CONSTRAINT_NAME
FROM
    INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS C
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS FK
    ON C.CONSTRAINT_NAME = FK.CONSTRAINT_NAME
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS PK
    ON C.UNIQUE_CONSTRAINT_NAME = PK.CONSTRAINT_NAME
INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE CU
    ON C.CONSTRAINT_NAME = CU.CONSTRAINT_NAME
INNER JOIN (
    SELECT
        i1.TABLE_NAME,
        i2.COLUMN_NAME
    FROM
        INFORMATION_SCHEMA.TABLE_CONSTRAINTS i1
    INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE i2
        ON i1.CONSTRAINT_NAME = i2.CONSTRAINT_NAME
    WHERE i1.CONSTRAINT_TYPE = 'PRIMARY KEY'
) PT
    ON PT.TABLE_NAME = PK.TABLE_NAME
0 голосов
/ 17 марта 2011
SELECT * FROM information_schema.columns WHERE table_name = 'Table Name' 
select * from INFORMATION_SCHEMA.TABLE_CONSTRAINTS where TABLE_NAME='Table Name'// It will list all the primary key and foreign key references.
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...