Oracle中,多表关联删除该怎么写?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle中,多表关联删除该怎么写?相关的知识,希望对你有一定的参考价值。
我建了两个表,p表和c表,现在想要在删除p表的一条数据的同时可以删掉c表中的一条数据,即p.p_id=c.p_id,请问应该怎样写?
参考技术A 只能一条一条的删除。。先删除子表。然后删除主表。一种是写两条sql语句。另外一种是写触发器。追问
请问具体该怎么写?触发器不怎么会用。。
追答你如果写在程序里面。你可以删除第一张表。
然后取出第一张的p_id。然后根据这个p_id 去删除第二张表!
具体怎么写。我就不给出来了。
触发器。就是这个功能。。更改表数据的时候。更改另外一张表。
你去查查资料。。应该不难。
。。好吧 谢谢了
追答怎么不采纳呢。哈哈!
多表级联删除表数据特别慢
删除表记录非常慢有好几个原因:1.机器性能问题,cpu被其他进程占用。这种方式最好解决,在进程管理器中关掉几个进程,释放出cpu用于处理删除记录操作;
2.sql语句本身优化,使用exists或者not exists比用“=”来的快;
3.表的关联关系影响了删除的速度。如果目标表和其它表建立了关联关系过多也会造成处理效率下降问题。如A表的和B表建立外关联的话,而B表又是一张很大的表,删除A表的记录时oracle执行过程是先在A表中选中一条记录进入待删除区,然后进行关联关系分析的,就是对B表进行全表查询一遍。同理如果A表和其它表 也有关联的话相同的查询也会在其它表中执行查询,等所有关联表查询完成确定没有引用关系的话,A表中选中记录会被打一个可以删除的标记,然后执行A表下一条的查询工作。值得注意的是被标记为可删除标记的记录不是立刻被删除的,删除操作一直要等到A表符合删除记录全部被打成可删除标记,删除操作才会被执行。如果有一条没有被标记成可删除标识的话,oracle 数据库会根据你设置给出相应的处理。
4.表与表引用关系存储在系统表dba_constraints 中,要有dba权限才能够执行的。查询语句如下:注意要更换'TableName':
select owner,constraint_name,CONSTRAINT_TYPE,TABLE_NAME
from dba_constraints
where r_constraint_name in (select CONSTRAINT_NAME from dba_constraints where table_name='TableName');
如果这个还不能解决问题的话。还有更复杂的办法。
5.使用oralce自带10046 的trace。该方法使用方法需要谨慎的,随用随关的。启用当前session的跟踪:
SQL> alter session set sql_trace=true; -- 开启trace
Session altered.
此时的SQL操作将被跟踪:
SQL> select count(*) from dba_users;
COUNT(*)
----------
34
结束跟踪:
SQL> alter session set sql_trace=false; --关闭trace
Session altered. 参考技术A 触发器问题。删除表数据特别慢是触发器问题。那些触发器使事情放慢了很多,因为那些级联的删除非常慢,通过在引用表上的外键字段上创建索引来解决这个问题。 参考技术B .
机器性能问题,cpu被其他进程占用。这种方式最好解决,在进程管理器中关掉几个进程,释放出cpu用于处理删除记录操作;
2.
sql语句本身优化,使用exists或者not exists比用“=”来的快;
3.
表的关联关系影响了删除的速度。如果目标表和其它表建立了关联关系过多也会造成处理 参考技术C 触发器问题。pgsql删除表数据特别慢是触发器问题。那些触发器使事情放慢了很多,因为那些级联的删除非常慢,通过在引用表上的外键字段上创建索引来解决这个问题。
以上是关于Oracle中,多表关联删除该怎么写?的主要内容,如果未能解决你的问题,请参考以下文章