日期:2014-05-16 浏览次数:20350 次
开发中碰到一个删除A表的记录之前要确定该记录在另外的B表C表等表中没有被使用,否则是不给删除A表中的该记录的。
想到了几个简单发方法,并对他们进行了测试和比较。记录下来以备后用。
1、select count(*) from?B?b where b.xx =? 'xx'--耗时3.104s
2、select 1 from B?b? where b.xx =? 'xx'--耗时0.047s
?
3_1、select 1 from dual where exists (select 1 from B?b? where b.xx =? 'xx')--耗时0.016s
?
3_2、select count(*) from dual where exists (select 1 from B?b? where b.xx =? 'xx')--耗时0.016s
?
测试时中B表中满足b.xx = 'xx'条件的记录100000以上。
?
?注:条件b.xx = 'xx'是A表和B表关联的条件。
?
采用3_2方法判断返回的结果是否大于0即可知道,2、3_1判断返回的结果集是否有记录。