Ответы:
Отказ от ответственности: я не знаю DB2.
Я просто погуглил их с "определением таблицы db2".
SELECT *
FROM SYSIBM.SYSTABLES TAB,SYSIBM.SYSCOLUMNS COL
WHERE TAB.CREATOR = COL.TBCREATOR
AND TAB.CREATOR = 'xxxx'
AND TAB.NAME = 'xxxxxxxxxxxxx'
AND TAB.NAME = COL.TBNAME
AND TAB.TYPE = 'V' ( OR 'T' )
ORDER BY 1,2;
SELECT * FROM syscat.tabconst WHERE type = 'P';
Вы можете сделать db2look
, который даст вам ddls для таблицы.
db2look -d db_name -e -x -z schema_name -t table_name
Вероятно, это самый простой вариант, поскольку первичный ключ поддерживается соответствующим индексом:
select COLNAMES from SYSIBM.SYSINDEXES where tbname = 'TABLE' and uniquerule = 'P';
Вы также можете запросить таблицу каталогов столбцов:
select NAME from SYSIBM.SYSCOLUMNS where tbname = 'TABLE' and keyseq > 0 order by keyseq;