存储过程实例(统计某用户下所有的表的记录数)

        写一个存储过程,统计某用户下所有表的记录数,并将其一一对应的插入表hr.count_all中(hr是Oracle默认存在的账户)

创建count_all的sql语句:

          create table hr.count_all(tablename  varchar2(50),

                                                         count   number);

        以下PL/SQL块(1)是错误的,在插入一条记录后,循环到第二条记录时会报错

因为if块里面那个字符串v_select_sql一直在增长而没有清空,很显然构造的是
非法的查询串;
(1):
declare
        cursor c_tab_name is select table_name from user_tables;
        
        tem_tab_name  varchar2(20);
        v_count number(8);
        
        v_select_sql varchar(200) default 'select count(*) from emcd.';
        v_insert_sql  varchar2(200) default 'insert into hr.count_all values(';
begin
        open c_tab_name;
        loop
                fetch c_tab_name into tem_tab_name;
                
                exit when c_tab_name%notfound;
                if tem_tab_name is not null then
                    dbms_output.put_line('table_name ==> '||tem_tab_name);
                    
                    v_select_sql := v_select_sql||tem_tab_name;
                    
                    dbms_output.put_line('v_select_sql ==> '||v_select_sql);
                    
                    execut
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值