ChatGPT解决这个技术问题 Extra ChatGPT

如何在 Oracle 中获取主键列?

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

在输入中,我只有表名。


R
Richie
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 以大写形式存储表名。


谢谢,里奇。还有一个问题:如何编码 'P' ?我需要使用“立即执行”来执行此操作。再次感谢。
我想你会像这样在它周围加上两个单引号''P''
或者,您可以使用 q quote it
和 constraint_type = 'R' 表示外键
当表格前没有模式前缀时为我工作!谢谢!
M
Mat

与“Richie”的答案相同,但更简洁一些。

仅查询用户约束 SELECT column_name FROM all_cons_columns WHERE constraint_name = ( SELECT constraint_name FROM user_constraints WHERE UPPER(table_name) = UPPER('tableName') AND CONSTRAINT_TYPE = 'P' );查询所有约束 SELECT column_name FROM all_cons_columns WHERE constraint_name = ( SELECT constraint_name FROM all_constraints WHERE UPPER(table_name) = UPPER('tableName') AND CONSTRAINT_TYPE = 'P' );


@FearlessFuture 对我来说效果很好。你能把你的问题描述得更有表现力吗?
我没有从这个查询中得到任何结果,但我确实从查询中得到了接受答案的结果。
@FearlessFuture 我假设您正在搜索的约束不是用户约束。将 user_constraints 替换为 all_constraints
如果您在两个或多个架构中有同名表,这会导致麻烦 - 还需要在联接中包括所有者:SELECT owner, column_name, position FROM all_cons_columns WHERE (owner, constraint_name) in (SELECT owner, constraint_name FROM all_constraints WHERE UPPER(table_name) = UPPER('&tableName') AND CONSTRAINT_TYPE = 'P') order by owner, position;
@MarkStewart 我同意第二个查询不起作用。但是您的解决方案效率低下。尝试:“SELECT cols.column_name AS KEY_STREAM, '=' AS KEY_CONDITION, cols.column_name as KEY_LOOKUP, '' AS KEY_STREAM2 FROM user_constraints cons, user_cons_columns cols WHERE cons.constraint_name = cols.constraint_name and CONSTRAINT_TYPE = 'P' and cons.table_name = '' 和 cons.table_name = cols.table_name;"
A
Alexander Hartmaier
Select constraint_name,constraint_type from user_constraints where table_name** **= ‘TABLE_NAME’ ;

(这将列出主键,然后)

Select column_name,position from user_cons_columns where constraint_name=’PK_XYZ’; 

(这会给你列,这里 PK_XYZ 是主键名称)


s
sainu

试试这个代码在这里我创建了一个表,用于在 oracle 中获取主键列,称为测试然后查询

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;

B
Bugalugs Nash

将以下脚本另存为 findPK.sql 之类的文件。

set verify off
accept TABLE_NAME char prompt 'Table name>'

SELECT cols.column_name
FROM all_constraints cons NATURAL JOIN all_cons_columns cols
WHERE cons.constraint_type = 'P' AND table_name = UPPER('&TABLE_NAME');

然后可以使用

@findPK