- 論壇徽章:
- 0
|
今天由于測試一個報表,必須要當(dāng)天的數(shù)據(jù),可我昨天剛測過,數(shù)據(jù)還在庫里,于是想偷個懶,手工修改時間字段為今天的日期,改了不到1分鐘,發(fā)現(xiàn)表太多了,而且記錄時間的字段每個表還不止一個,不如用程序來做。于是寫了下面的這個存儲過程,哈哈,好用- /*
- *搜索數(shù)據(jù)庫當(dāng)前用戶的所有表,查出所有含date和time名稱,
- *并且是number(14)類型的字段的日期部分改為當(dāng)前日期
- */
- declare
- type tcur is ref cursor; --定義游標類型
- columnsCur tcur; --定義表的字段游標
- sTName varchar(30);--存儲表名
- sCName varchar(30);--存儲字段名
- nCurrentTime number(14); --存儲當(dāng)前日期
- updstr varchar(900);
- begin
- --獲取當(dāng)前日期YYYYMMDD
- select to_number(to_char(sysdate, 'YYYYMMDD') || '000000')
- into nCurrentTime
- from dual;
- --從oracle系統(tǒng)表獲取包含數(shù)字日期形式的字段名和對應(yīng)的表名
- OPEN columnsCur for
- select p.TABLE_NAME, p.COLUMN_NAME
- from user_tab_columns p
- where p.TABLE_NAME IN ('OPENORDER',
- 'ORDERINSTRUCTION',
- 'INSTRUCTIONDETAIL',
- 'INTELLIGENTORDER',
- 'TRADINGRESULT')
- and p.DATA_TYPE = 'NUMBER' and p.DATA_PRECISION=14
- and (p.COLUMN_NAME like '%DATE%' or p.COLUMN_NAME like '%TIME%');
- --根據(jù)獲得的表名和字段名把目前的時間更新為當(dāng)前日期,時間保持不變
- loop
- fetch columnsCur
- into sTName, sCName;
- exit when columnsCur%notfound;
- begin
- --執(zhí)行更新
- updstr := 'UPDATE ' || sTName || ' SET ' || sCName || '=' ||
- nCurrentTime || '+ to_number(nvl(substr(' || sCName ||
- ', 9), 0)) where ' || sCName || ' IS NOT NULL AND ' || sCName || '>0';
- --debug
- --dbms_output.put_line(updstr);
- execute immediate updstr;
- exception
- --如果發(fā)生錯誤,打印出執(zhí)行的sql
- when others then
- dbms_output.put_line('Error:' || updstr);
- end;
- end loop;
- commit;
- end;
復(fù)制代碼 |
|