首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle:动态SQL

Oracle:动态SQL
EN

Stack Overflow用户
提问于 2013-05-01 22:50:12
回答 1查看 416关注 0票数 1

我正在尝试写Oracle动态SQL来做行数统计,下面是我的做法,请帮我完成。

这是我用来生成单个计数语句的select语句:

代码语言:javascript
复制
select 'select count(*) from '||table_name||';'
from dba_tables
where owner = 'URR';

我是这样开始的:

代码语言:javascript
复制
declare
  l_owner varchar2(30) := 'URR';
  l_table_name varchar2(30);
  l_columns varchar2(32000);
  l_sql varchar2(32000);
begin
EN

回答 1

Stack Overflow用户

发布于 2013-05-01 23:15:21

下面是一个简单的示例,它查看您自己的模式中的表:

代码语言:javascript
复制
set serveroutput on
declare
    c number;
begin
    for r in (select table_name from user_tables) loop
        execute immediate 'select count(*) from ' || r.table_name
            into c;
        dbms_output.put_line(r.table_name ||': '|| c);
    end loop;
end;
/

要查看其他人的表,您需要在开始尝试时使用dba_tables,或者更有可能使用all_tables,因为它应该排除您无法计算的表,但是您还需要在count语句中指定所有者。

通常情况下,您会希望使用绑定变量来避免SQL注入,但是您必须使用下面这样的连接来指定对象名称。

其他需要注意的是,您在查询中有一个错误,但Egor现在已将其从问题中删除。您执行的动态SQL字符串不应以分号(;)结尾。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16320425

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档