正如标题所示,我很好奇,如果有人知道如何查询表的主键,其数据类型和主键列的名称。今天早些时候,我单独询问了主键列,并且运行良好。但是,我不确定如何提取其数据类型和列名。任何帮助,将不胜感激。主键,其数据类型及其列名的SQL查询?
谢谢!
正如标题所示,我很好奇,如果有人知道如何查询表的主键,其数据类型和主键列的名称。今天早些时候,我单独询问了主键列,并且运行良好。但是,我不确定如何提取其数据类型和列名。任何帮助,将不胜感激。主键,其数据类型及其列名的SQL查询?
谢谢!
使用查询表user_tab_columns
或all_tab_columns
:
select column_name, data_type, data_length from user_tab_columns
where table_name = 'MY_TABLE';
select * from all_tab_columns
where owner = 'THE_SCHEMA_OWNER';
如果以“THE_SCHEMA_OWNER”身份登录,还可以选择查询user_tab_cols。 – dseibert 2011-03-18 21:49:47
这应做到:
SELECT ac.constraint_name, acc.column_name, acc.position
, atc.data_type, atc.data_length
FROM all_constraints ac JOIN all_cons_columns acc
ON (ac.CONSTRAINT_NAME = acc.CONSTRAINT_NAME)
JOIN all_tab_cols atc ON (ac.owner = atc.owner AND
ac.table_name = atc.TABLE_NAME AND
acc.COLUMN_NAME = atc.COLUMN_NAME)
WHERE ac.owner = 'table_owner'
AND ac.table_name = 'your_table'
AND ac.constraint_type = 'P'
ORDER BY acc.position;
注意,主键可以由多个列的。 – DCookie 2011-03-18 21:56:26