java怎么删除未命名的外键_oracle 删除未命名外键问题

展开全部

如果你 SQL  里面, 没有给 外键起名字,  那么数据库会 自动使用一个62616964757a686964616fe58685e5aeb931333264656133   算法, 来产生一个 唯一的名字

下面这个 SQL  用于在 Oracle 里面, 查询 所有的   外键信息。

你可以  通过  子表名 , 去查询, 那个 自动生成的 外键名字, 是什么。

然后就可以删除了。

SELECT

USER_CONS_COLUMNS.CONSTRAINT_NAME AS 约束名,

USER_CONS_COLUMNS.TABLE_NAME AS 子表名,

USER_CONS_COLUMNS.COLUMN_NAME AS 子表列名,

USER_CONS_COLUMNS.POSITION AS 位置,

USER_INDEXES.TABLE_NAME AS 主表名,

USER_IND_COLUMNS.COLUMN_NAME AS 主表列名

FROM

USER_CONSTRAINTS

JOIN USER_CONS_COLUMNS

ON (USER_CONSTRAINTS.CONSTRAINT_NAME

= USER_CONS_COLUMNS.CONSTRAINT_NAME)

JOIN USER_INDEXES

ON (USER_CONSTRAINTS.R_CONSTRAINT_NAME

= USER_INDEXES.INDEX_NAME)

JOIN USER_IND_COLUMNS

ON (USER_INDEXES.INDEX_NAME = USER_IND_COLUMNS.INDEX_NAME)

WHERE

CONSTRAINT_TYPE = 'R';

至于如何 删除 外键 ,  语法是

ALTER TABLE   表名   DROP CONSTRAINT   外键约束名字;

至于

用指定内容为什么不好用呢?

这个因为 Oracle 的 语法不支持你这么做

因此你没法这么干.

4ccbc3df5baab20835931835c5af3d7f.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值