查询schema下所有表的记录数

本文介绍了一种通过创建自定义函数来查询特定schema下所有表的记录数的方法,并提供了具体的PL/SQL代码实现。该方法适用于需要快速了解多个表数据规模的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

3. 查询schema下所有表的记录数
-- 创建计算表记录数的函数[@more@]3. 查询schema下所有表的记录数
-- 创建计算表记录数的函数
CREATE OR REPLACE FUNCTION sf_tab_count(iv_table_name IN VARCHAR2)
RETURN NUMBER IS
v_cursor_handle INTEGER; -- 句柄
v_count INTEGER; -- 计数器
v_text VARCHAR2(4000); -- 运算PL/SQL串
r_num NUMBER;
BEGIN
v_text := v_text || 'DECLARE v_num NUMBER; BEGIN SELECT COUNT(*) INTO :v_num FROM '||iv_table_name||'; END;';
IF DBMS_SQL.IS_OPEN(v_cursor_handle) THEN
DBMS_SQL.CLOSE_CURSOR(v_cursor_handle);
END IF;
v_cursor_handle := DBMS_SQL.OPEN_CURSOR;
DBMS_SQL.PARSE(v_cursor_handle, v_text, DBMS_SQL.NATIVE);
DBMS_SQL.BIND_VARIABLE(v_cursor_handle, 'v_num', r_num);
v_count := DBMS_SQL.EXECUTE(v_cursor_handle);
DBMS_SQL.VARIABLE_VALUE(v_cursor_handle, 'v_num', r_num);
DBMS_SQL.CLOSE_CURSOR(v_cursor_handle);
RETURN r_num;
EXCEPTION
WHEN OTHERS THEN
DBMS_SQL.CLOSE_CURSOR(v_cursor_handle);
RETURN NULL;
END sf_tab_count;
-- 查询schema下表的记录数
SELECT owner "用户", table_name "表名", sf_tab_count(owner||'.'||table_name) "记录数" FROM DBA_TABLES
WHERE owner IN ('HR', 'SCOTT')
ORDER BY owner, table_name;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/54593/viewspace-1017239/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/54593/viewspace-1017239/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值