亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Access > 正文

Oracle與Access表之間的導入和導出實現

2024-09-07 19:05:07
字體:
來源:轉載
供稿:網友

  問題的提出:如何在FORM的程序中實現Oracle與access表之間的導入和導出。

  問題的解答:

  準備工作:

  1.安裝OCA。運行Developer的安裝盤,選擇自定義安裝,選擇Oracle Open Client Adapter for ODBC安裝。

  2.在數據源(ODBC)中添加DSN。控制面板->管理工具->數據源(ODBC),選擇“用戶DSN”,添加要進行操作的Access的文件。在“高級”選項里,填上“登錄名稱”和“密碼”(很重要,在程序中會用到)。

  下面以實際例子來說明:

  假設在Oracle中和Access中都有一個student表,表中字段相同(name char(10) ,age number(2)),在準備工作2中的“數據源名”為test,“登錄名稱”和“密碼”都為user。

  下面為從Oracle導出到Access的PRocedure:

以下是引用片段:
  PROCEDURE oracle_to_access IS
  connection_id EXEC_SQL.ConnType;
  action_cursor EXEC_SQL.CursType;
  ignore PLS_INTEGER;
  t_name student.name%type;
  t_age student.age%type;
  cursor temp_cursor is select * from student;
  BEGIN
  connection_id:= EXEC_SQL.OPEN_CONNECTION('user/user@odbc:test');
  action_cursor := EXEC_SQL.OPEN_CURSOR(connection_id);
  EXEC_SQL.PARSE(connection_id, action_cursor,'delete * from student');
  ignore := EXEC_SQL.EXECUTE(connection_id, action_cursor);
  EXEC_SQL.CLOSE_CURSOR(connection_id,action_cursor);
  open temp_cursor;
  export_count := 0;
  action_cursor := EXEC_SQL.OPEN_CURSOR(connection_id);
  EXEC_SQL.PARSE(connection_id, action_cursor,'INSERT INTO student(name,age) values(:1,:2)');
  loop
  fetch temp_cursor into t_name,t_age;
  exit when temp_cursor%notfound;
  EXEC_SQL.BIND_VARIABLE(connection_id,action_cursor, ':1', t_name);
  EXEC_SQL.BIND_VARIABLE(connection_id,action_cursor, ':2', t_age);
  ignore := EXEC_SQL.EXECUTE(connection_id, action_cursor);
  end loop;
  close temp_cursor;
  EXEC_SQL.PARSE(connection_id, action_cursor,'commit');
  ignore := EXEC_SQL.EXECUTE(connection_id,action_cursor);
  EXEC_SQL.CLOSE_CURSOR(connection_id,action_cursor);
  EXEC_SQL.CLOSE_CONNECTION(connection_id);
  EXCEPTION
  WHEN EXEC_SQL.PACKAGE_ERROR THEN
  IF EXEC_SQL.LAST_ERROR_CODE(connection_id) != 0 THEN
  message('數據導出至ACCESS失敗: ' || TO_CHAR(EXEC_SQL.LAST_ERROR_CODE(connection_id)) || ': ' || EXEC_SQL.LAST_ERROR_MESG(connection_id));
  END IF;
  IF EXEC_SQL.IS_CONNECTED(connection_id) THEN
  IF EXEC_SQL.IS_OPEN(connection_id,action_cursor) THEN
  EXEC_SQL.CLOSE_CURSOR(connection_id,action_cursor);
  END IF;
  EXEC_SQL.CLOSE_CONNECTION(connection_id);
  END IF;
  END;
  下面為從Access導出到Oracles的procedure:
  PROCEDURE Access_to_oracle IS
  connection_id EXEC_SQL.ConnType;
  action_cursor EXEC_SQL.CursType;
  ignore PLS_INTEGER;
  t_name student.name%type;
  t_age student.age%type;
  BEGIN
  connection_id := EXEC_SQL.OPEN_CONNECTION('user/user@odbc:test');
  action_cursor := EXEC_SQL.OPEN_CURSOR(connection_id);
  delete from student;
  EXEC_SQL.PARSE(connection_id, action_cursor,'select name,age from student');
  ignore := EXEC_SQL.EXECUTE(connection_id, action_cursor);
  exec_sql.define_column(connection_id,action_cursor,1,t_name,10);
  exec_sql.define_column(connection_id,action_cursor,2,t_age);
  ignore := EXEC_SQL.EXECUTE(connection_id, action_cursor);
  while(exec_sql.fetch_rows(connection_id,action_cursor)>0)
  loop
  exec_sql.column_value(connection_id,action_cursor,1,t_name);
  exec_sql.column_value(connection_id,action_cursor,2,t_age);
  insert into test(name,age) values(t_name,t_age);
  end loop;
  commit;
  EXEC_SQL.CLOSE_CURSOR(connection_id,action_cursor);
  EXEC_SQL.CLOSE_CONNECTION(connection_id);
  EXCEPTION
  WHEN EXEC_SQL.PACKAGE_ERROR THEN
  IF EXEC_SQL.LAST_ERROR_CODE(connection_id) != 0 THEN
  message('數據導入至ORACLE失敗: ' || TO_CHAR(EXEC_SQL.LAST_ERROR_CODE(connection_id)) || ': ' || EXEC_SQL.LAST_ERROR_MESG(connection_id));
  END IF;
  IF EXEC_SQL.IS_CONNECTED(connection_id) THEN
  IF EXEC_SQL.IS_OPEN(connection_id,action_cursor) THEN
  EXEC_SQL.CLOSE_CURSOR(connection_id,action_cursor);
  END IF;
  EXEC_SQL.CLOSE_CONNECTION(connection_id);
  END IF;
  END;


  注意:EXEC_SQL.BIND_VARIABLE中綁定的變量只能是以下三種類型:NUMBER,DATE,VARCHAR2。對于Access中的“是/否”的布爾型變量,可以用NUMBER類型的1和0來表示。如果Access中的表名或者字段名中有空格,在寫SQL語句的時候可以用雙引號把表名或者字段名包括起來,如:本例中如果Access中表名為student detail,字段名分別為student name和student age,那插入數據的SQL語句為:insert into “student detail”(“student name”,”student age”) values(:1,:2)。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩av电影中文字幕| 久久影院中文字幕| 性欧美暴力猛交69hd| 欧美激情精品久久久久久免费印度| 国产成人在线一区| 欧美大尺度电影在线观看| 97**国产露脸精品国产| 亚洲国产成人在线视频| 国产一区二区视频在线观看| 欧美激情免费观看| 国产精品久久久久久久久久三级| 亚洲激情小视频| 欧美亚洲午夜视频在线观看| 亚洲欧美制服综合另类| 欧美午夜精品久久久久久浪潮| 欧美在线激情视频| 亚洲欧美综合另类中字| 久久精品亚洲94久久精品| 日本一区二区在线播放| 精品国产31久久久久久| 欧美有码在线观看视频| 欧美精品在线免费播放| 97久久精品人搡人人玩| 91久久国产婷婷一区二区| 久久九九亚洲综合| 97香蕉超级碰碰久久免费软件| 另类色图亚洲色图| 欧美日本黄视频| 亚洲黄页视频免费观看| 欧美极品欧美精品欧美视频| 高清日韩电视剧大全免费播放在线观看| 欧美成aaa人片在线观看蜜臀| 国产精品久久久久久五月尺| 亚洲电影免费观看高清完整版在线| 亚洲精品一区二区三区婷婷月| 日韩精品中文字幕有码专区| 成人午夜在线观看| 97视频在线观看免费高清完整版在线观看| 亚洲欧美国产精品久久久久久久| 国产91对白在线播放| 国产欧美精品va在线观看| 亚洲精品xxxx| 精品国产欧美一区二区五十路| 国产日韩精品视频| 日韩视频免费看| 国产精品久久久久久久av大片| 国产美女高潮久久白浆| 欧美日韩加勒比精品一区| 欧美人在线观看| 69**夜色精品国产69乱| 538国产精品一区二区免费视频| 成人国产精品久久久久久亚洲| 欧美极品美女视频网站在线观看免费| 亚洲激情视频在线播放| 国产精品中文久久久久久久| 欧美午夜精品久久久久久人妖| 91久久精品国产91性色| 成人精品一区二区三区电影黑人| 亚洲黄色www网站| 欧美日韩一区二区在线播放| 性色av一区二区三区免费| 国产亚洲视频在线观看| 欧美国产日韩精品| 国产成人高潮免费观看精品| 国内精品一区二区三区| 国产99久久精品一区二区 夜夜躁日日躁| 91久久精品国产91久久| 欧美高清电影在线看| 日韩女在线观看| 国产欧美精品久久久| 久久久噜久噜久久综合| 亚洲第一精品夜夜躁人人爽| 亚洲人免费视频| 一区二区三区回区在观看免费视频| 在线观看国产成人av片| 亚洲国产精品久久久| 亚洲一区二区三区在线视频| 国产精品久久久久久中文字| 久久精品视频免费播放| 亚洲视频综合网| 777午夜精品福利在线观看| 国产精品久久久久久久app| 国产欧美日韩精品专区| 国产成人啪精品视频免费网| 热99精品里视频精品| 久久久久久久久久久久av| 国产精品丝袜一区二区三区| 亚洲专区中文字幕| 亚洲丝袜在线视频| 国产日韩av在线播放| 国产91精品高潮白浆喷水| 久久亚洲精品网站| 欧美成人sm免费视频| 日韩久久免费电影| 亚洲在线免费观看| 成人性生交xxxxx网站| 日韩在线视频线视频免费网站| 亚洲成avwww人| 欧美激情极品视频| 久久韩剧网电视剧| 日韩在线免费高清视频| 日韩欧美国产成人| 亚洲精品资源美女情侣酒店| 国产精品直播网红| 日韩av成人在线观看| 在线观看亚洲区| 超碰日本道色综合久久综合| 91啪国产在线| 成人字幕网zmw| 日本欧美爱爱爱| 91在线视频导航| 国产91精品不卡视频| 欧美视频一区二区三区…| 91国产一区在线| 欧美成人三级视频网站| 中文字幕一精品亚洲无线一区| 日韩精品极品视频免费观看| 国产精品丝袜白浆摸在线| 伊人男人综合视频网| 欧美精品做受xxx性少妇| 久久视频在线观看免费| 久久夜色精品亚洲噜噜国产mv| www.日韩不卡电影av| 久久久久久久久电影| 亚洲bt欧美bt日本bt| 国产精品久久久久久久久| 精品在线欧美视频| 91久久久久久久一区二区| 91精品国产综合久久久久久蜜臀| 日韩av一区二区在线| 91精品久久久久久久久久久久久久| 91网站免费看| 日韩av在线影院| 欧美激情视频在线免费观看 欧美视频免费一| 神马国产精品影院av| 日本中文字幕久久看| 国产精品黄页免费高清在线观看| 欧美精品激情在线观看| 亚洲国产成人在线视频| 成人免费自拍视频| 欧美激情aaaa| 欧美与黑人午夜性猛交久久久| 亚洲欧洲日产国码av系列天堂| 成人羞羞国产免费| 亚洲男人天堂网站| 538国产精品一区二区在线| 日韩免费高清在线观看| 欧美专区在线视频| 亚洲无限乱码一二三四麻| 中文国产亚洲喷潮| 亚洲第一精品福利| 日韩电影大片中文字幕| 黑人巨大精品欧美一区二区| 欧美激情精品久久久久久大尺度| 日韩欧美中文免费| 免费97视频在线精品国自产拍| 91久久精品美女| www.欧美视频| 亚洲人成电影在线播放| 久久国产视频网站| 成人国产在线激情| 91欧美精品午夜性色福利在线| 欧美乱大交做爰xxxⅹ性3| 久久在线观看视频|