国产探花免费观看_亚洲丰满少妇自慰呻吟_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;
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 英吉沙县| 绥棱县| 锡林浩特市| 肇庆市| 阿巴嘎旗| 广水市| 金寨县| 奇台县| 巩义市| 耒阳市| 比如县| 吉木乃县| 彭山县| 文山县| 威远县| 祁阳县| 洞口县| 刚察县| 方城县| 东至县| 嘉义县| 蕉岭县| 桦川县| 理塘县| 宜兰市| 龙岩市| 星子县| 大安市| 昌图县| 正镶白旗| 满洲里市| 大余县| 赤峰市| 饶阳县| 皋兰县| 万全县| 鹿泉市| 汕头市| 连州市| 大渡口区| 屏边|