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

首頁 > 開發 > 綜合 > 正文

在Oralce9i內向給定的表對象內插入實際的行

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

     在開發數據庫程序時,經常需要象數據庫表對象內錄入些測試數據,如果針對每個表對象都建立一個錄入的存儲過程,顯得有些麻煩。這里給出一個示例pl/sql代碼,調用者給出要插入測試數據的表對象名稱,和待插入的行數后,過程即可產生隨機數據,錄入到表對象內。

/*-------------向給定的表對象內插入實際的行。---------------------------*/
  procedure insert_rows(p_tablename varchar, p_numrows number)
  as
    --定義dba_tab_columns視圖類型的表對象,用于存儲給定表的字段的定義信息
    type table_define is table of dba_tab_columns%rowtype index by binary_integer;
    td table_define;
    i binary_integer;

    --定義動態sql查詢的游標
    l_cursor number:= dbms_sql.open_cursor;
    l_ignone number;
    --動態sql語句字符變量
    sqlstr varchar2(1000);
  begin
    --獲得表的所有字段的定義信息
    i:=0;
    for rec in(select * from dba_tab_columns where table_name=upper(p_tablename))
    loop
      i:= i+1;
      td(i):= rec;
      dbms_output.put_line(td(i).table_name);
    end loop;
    --組織insert sql語句的字段字符串
    sqlstr:='insert into '||td(1).table_name||'(';
    for var in 1..i loop
      sqlstr:=sqlstr||td(var).column_name;
      if(var<>i) then
        sqlstr:=sqlstr||',';
      end if;
    end loop;
    --組織insert sql語句的參數字符串
    sqlstr:=sqlstr||')'||'values(';
    for var in 1..i loop
     sqlstr:=sqlstr||':'||td(var).column_name;
     if(var<>i) then
       sqlstr:=sqlstr||',';
     end if;
    end loop;
    sqlstr:=sqlstr||')';

    dbms_output.put_line(sqlstr);

    --為參數變量賦值
    dbms_sql.parse(l_cursor,sqlstr,dbms_sql.native);
   
    for var_rows in 1..p_numrows loop
      --填充插入參數的值
      for var in 1..i loop
        if td(var).data_type='varchar2' then
          dbms_sql.bind_variable(l_cursor,':'||td(var).column_name,dbms_random.string('a',td(var).data_length));
        elsif td(var).data_type='number' then
          dbms_sql.bind_variable(l_cursor,':'||td(var).column_name,
          round(dbms_random.value*power(10,td(var).data_precision-td(var).data_scale),td(var).data_scale));
        else
          dbms_sql.bind_variable(l_cursor,':'||td(var).column_name,'unknow_type');
        end if;
      end loop;
      --執行動態的sql語句
      l_ignone:=dbms_sql.execute(l_cursor);
    end loop; 
    commit;
    dbms_sql.close_cursor(l_cursor);
   
  end insert_rows;
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 库伦旗| 千阳县| 孟津县| 广东省| 陇西县| 泗水县| 寿宁县| 大竹县| 红安县| 石柱| 宁国市| 会东县| 扎赉特旗| 安义县| 昌乐县| 会泽县| 新津县| 旬阳县| 济源市| 九龙县| 盐城市| 乐清市| 年辖:市辖区| 九江县| 吉安市| 青田县| 绥化市| 大石桥市| 洱源县| 福贡县| 云霄县| 防城港市| 珠海市| 祁连县| 汝阳县| 开远市| 南开区| 平山县| 梓潼县| 磴口县| 新竹市|