首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在Oracle中获取主键列?

如何在Oracle中获取主键列?
EN

Stack Overflow用户
提问于 2012-01-26 18:14:38
回答 4查看 306.4K关注 0票数 125

我需要获取主键列的名称。

在输入中,我只有表名。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-01-26 18:26:07

代码语言:javascript
复制
SELECT cols.table_name, cols.column_name, cols.position, cons.status, cons.owner
FROM all_constraints cons, all_cons_columns cols
WHERE cols.table_name = 'TABLE_NAME'
AND cons.constraint_type = 'P'
AND cons.constraint_name = cols.constraint_name
AND cons.owner = cols.owner
ORDER BY cols.table_name, cols.position;

确保'TABLE_NAME‘是大写的,因为Oracle存储的表名是大写的。

票数 215
EN

Stack Overflow用户

发布于 2013-04-25 22:00:24

代码语言:javascript
复制
Select constraint_name,constraint_type from user_constraints where table_name** **= ‘TABLE_NAME’ ;

(这将列出主键,然后)

代码语言:javascript
复制
Select column_name,position from user_cons_cloumns where constraint_name=’PK_XYZ’; 

(这将为您提供列,其中PK_XYZ是主键名称)

票数 2
EN

Stack Overflow用户

发布于 2017-05-24 19:22:03

在这里我为oracle中的get primary key column创建了一个名为test然后query的表

代码语言:javascript
复制
create table test
(
id int,
name varchar2(20),
city varchar2(20),
phone int,
constraint pk_id_name_city primary key (id,name,city)
);

SELECT cols.table_name, cols.column_name, cols.position, cons.status, cons.owner FROM all_constraints cons, all_cons_columns cols WHERE cols.table_name = 'TEST' AND cons.constraint_type = 'P' AND cons.constraint_name = cols.constraint_name AND cons.owner = cols.owner  ORDER BY cols.table_name, cols.position;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9016578

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档