国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

如何利用DBMS_SQL包和游標計算當前用戶下所有表的行數

2024-07-21 02:34:28
字體:
來源:轉載
供稿:網友

  系統環境: 1、操作系統:windows 2000,機器內存128M
  2、數據庫: Oracle 8i R2 (8.1.6) for NT 企業版
  3、安裝路徑:C:/ORACLE
  
   實現方法:
   
  SQL> conn scott/tiger
  SQL> set serveroutput on size 1000000
  SQL>
  SQL> DECLARE
   2 t_c1_tname user_tables.table_name%TYPE;
   3 t_command varchar2(200);
   4 t_cid integer;
   5 t_total_records number(10);
   6 stat integer;
   7 row_count integer;
   8 t_limit integer := 0; --限制只取出記錄大于0的表的情況
   9 cursor c1 is select table_name from user_tables order by table_name; --查出所有表的名字
   10 BEGIN
   11 t_limit := 0;
   12 open c1;
   13 loop
   14 fetch c1 into t_c1_tname; --取出一個表名
   15 exit when c1%NOTFOUND; --假如游標記錄取完,退出循環
   16 t_command := 'SELECT COUNT(0) FROM 't_c1_tname; --定義SQL命令
   17 t_cid := DBMS_SQL.OPEN_CURSOR; --創建一個游標
   18 DBMS_SQL.PARSE(t_cid,t_command,dbms_sql.native); --向服務器發出一個語句并檢查這個語句的語法和語義錯誤
   19 DBMS_SQL.DEFINE_COLUMN(t_cid,1,t_total_records); --定義將從FetchRows()函數接收數據的變量的數據類型與大小
   20 stat := DBMS_SQL.EXECUTE(t_cid); --執行此語句,因為執行的是查詢,所以必須跟著Fetch_Rows函數并為單個行檢索數據
   21 row_count := DBMS_SQL.FETCH_ROWS(t_cid); --取回一行數據放入局部緩沖區
   22 DBMS_SQL.COLUMN_VALUE(t_cid,1,t_total_records); --返回調用FetchRows()取回的一列的值,這一列的值存儲在t_total_records中
   23 if t_total_records > t_limit then
   24 DBMS_OUTPUT.PUT_LINE(rpad(t_c1_tname,55,' ')
   25 to_char(t_total_records,'99999999')' record(s)');
   26
   27 end if;
   28 DBMS_SQL.CLOSE_CURSOR(t_cid);
   29 end loop;
   30 close c1;
   31 END;
   32 /
  DEPT 4 record(s)
  EMP 14 record(s)
  SALGRADE 5 record(s)
  
  PL/SQL 過程已成功完成。

上一篇:查看各種對象的SQL

下一篇:PL/SQL的異常

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 庆阳市| 甘孜| 许昌市| 平罗县| 柳江县| 武宣县| 垣曲县| 平阳县| 柘荣县| 三原县| 邢台市| 赤峰市| 四子王旗| 康平县| 台北市| 眉山市| 嘉兴市| 沾益县| 来凤县| 陆良县| 读书| 绥德县| 昭苏县| 合作市| 库伦旗| 德令哈市| 大余县| 上蔡县| 沐川县| 平舆县| 怀仁县| 哈巴河县| 津南区| 普宁市| 云和县| 德保县| 桑日县| 海兴县| 积石山| 晴隆县| 青神县|