oracle 查询外键的名称

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle 查询外键的名称相关的知识,希望对你有一定的参考价值。

【禁用student表cid列上得外键约束】
我用的ALTER TABLE STUDENT DISABLE foreing key(cid);
不对,同学说是应该ALTER TABLE STUDENT DISABLE foreing key 外键约束在表里的名称
在创建表时 我没有定义外键约束的名称,应该是系统自动给的吧,应该怎么查询这个名称呢?

或者是 禁用外键约束还有没有其他的方法?

需要通过查询系统表user_constraints来获得外键名称。

例如,查询跟emp表相关的外键,可用如下语句:

select * from user_constraints where table_name=\'EMP\';

查询结果:

其中红框部分即为外键名称。

参考技术A 可以查询外键的名称
SELECT *
FROM user_constraints
WHERE CONSTRAINT_TYPE = 'R' AND TABLE_NAME = ''追问

我执行了 但是显示
【未选定行】?

追答

是原样执行的吗?table_name=你自己的表名,如果还是没有,你就把 CONSTRAINT_TYPE = 'R' AND 条件去掉,看看你的表上到底有什么约束

追问

我要查询的是STUDENT表的约束名称
这是我的代码
SELECT * FROM USER_CONSTRAINTS
WHERE CONSTRAINT_TYPE = 'R' AND TABLE_NAME = 'STUDENT';

追答

SELECT * FROM USER_CONSTRAINTS
WHERE TABLE_NAME = 'STUDENT';
这样试试看看表'STUDENT'上有那些约束
你还可以使用toad工具,一目了然

本回答被提问者和网友采纳

oracle怎么查看外键在哪个表

有时候删除某张表记录的时候,会报错外键约束不能删除。

如果不了解表之间的关系,可以通过以下语句查询到外键是建在哪张表上的:

select * from dba_constraints where constraint_name=\'xxx\' and constraint_type = \'R\';

例如:我的程序日志中报如下错误,我要知道外键是在那个表上.
2015-09-08
18:28:18 [ main:261597003 ] - [ ERROR ] java.sql.SQLException:
ORA-02291: 违反完整约束条件 (IRP.FK66EC57AF5158B9FB) - 未找到父项关键字

select * from dba_constraints where constraint_name=\'FK66EC57AF5158B9FB\' and constraint_type = \'R\';

例如:

执行delete from tablename时报错:

ORA-02292: integrity constraint (CCSYS.FK_T_BME_TASKRUNRESULT_TASKID) violated - child record found

可以通过执行

select table_name from dba_constraints where constraint_name=\'FK_T_BME_TASKRUNRESULT_TASKID\' and constraint_type = \'R\';

查询出外键是建在T_BME_TASKRUNRESULT表上的,先把T_BME_TASKRUNRESULT表删除,就可以删除 t_bme_task表记录了。
参考技术A 如果不了解表之间的关系,可以通过以下语句查询到外键是建在哪张表上的:
select * from dba_constraints where constraint_name='xxx' and constraint_type = 'R';
例如:我的程序日志中报如下错误,我要知道外键是在那个表上.
2015-09-0818:28:18 [ main:261597003 ] - [ ERROR ] java.sql.SQLException:
ORA-02291: 违反完整约束条件 (IRP.FK66EC57AF5158B9FB) - 未找到父项关键字
select * from dba_constraints where constraint_name='FK66EC57AF5158B9FB' and constraint_type = 'R';本回答被提问者采纳

以上是关于oracle 查询外键的名称的主要内容,如果未能解决你的问题,请参考以下文章

oracle怎么查看外键在哪个表

查询表的外键关系

多表查询

oracle数据库设置外键问题

django 查询具有外键的模型,检查该外键的属性

oracle怎么查询所有的表有没有主键