oracle 我有1000条查询语句,通过执行每一条sql语句,返回所有的查询结果为空的记录,能实现吗?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle 我有1000条查询语句,通过执行每一条sql语句,返回所有的查询结果为空的记录,能实现吗?相关的知识,希望对你有一定的参考价值。

例如: select *from tab t where t.id='16299';

select *from tab t where t.id='16300';

select *from tab t where t.id='16301' ;

select *from tab t where t.id='16302' ;
这4条sql语句中 第二三两条sql 查询结果为空,就输出或者返回这两个sql,或者返回查询条件id

可以实现,利用oracle的存储过程,用指针,很容易就解决了。因为指针就是一个for循环,在该循环裏面可以处理每一条数据。希望对你有用追问

可不可以写个简单的例子?我对数据库的操作不是很熟悉?

参考技术A 不能!不能!不能!追问

我只能分配执行 比如一次执行10个 然后手动检出查询记录为空的吗?

追答

举个例子说明更好

追问

例子 我已经补充了!

参考技术B 你表里面至少有一个字段不是空才行吧。
比如 主键

id name email

你要查name email 是空的。

select * from user where name is null and email is null

如果有更多的字段你继续加 and 就可以了。

这个查出来的结果,,其他字段都是空的 只有一个id追问

不是 是有很多查询的sql语句,需要每一个sql语句 执行为空的记录

追答

你至少有一个不为空才能查到,你是查询很多表吧??

追问

我把例子补充上去了,我有1000条sql语句 查询的是同一张表,因为查询条件不同,所以查询结果各异。需要所有的查不到记录的sql

追答

select case when (select *from tab t where t.id='16301' ;
) is not null then '' else '16301' end from dual;

本回答被提问者采纳
参考技术C 用procedure?

oracle存储过程中执行查询sql语句报错

Create Or Replace Procedure UP_ExecSqlProcForDS(strSql In Varchar2,cur_out Out sys_refcursor)
As
Begin
Open cur_out For
Execute immediate strSql;
End;
strSql是一条查询sql语句,类似于select * from table,我想要的是给存储过程传一个查询的sql语句,然后存储过程给我返回结果集,怎么弄?

参考技术A 你这种可以用函数来实现
CREATE OR REPLACE FUNCTION UP_ExecSqlProcForDS RETURN NUMBER IS

CURSOR tmcur_out IS
select *from table
;
begin
FOR l_cur IN tmcur_out LOOP
end loop
exception
end
这个只是框架,你自己可以 根据自己的需要作适当修改
参考技术B Open cur_out For strsql;
这个是么?
这是定义游标的使用方法,游标的语法是一个SELECT语句的字符串

type cursor_type is ref cursor;
c1 cursor_type;

open c1 for selectsql;
参考技术C CREATE OR REPLACE Procedure UP_ExecSqlProcForDS(strSql In Varchar2,cur_out Out sys_refcursor)
As
Begin
Open cur_out For
strSql;
End;本回答被提问者采纳
参考技术D 我空间有个关于存储过程的,看看能不能帮到你。

以上是关于oracle 我有1000条查询语句,通过执行每一条sql语句,返回所有的查询结果为空的记录,能实现吗?的主要内容,如果未能解决你的问题,请参考以下文章

数据库操作,需要执行1000条SQL语句。

sql语句查询如何显示第一条数据

Oracle死锁查询及处理

Oracle with重用子查询

Oracle in查询1000条限制的解决方案

sql执行计划