清华大佬耗费三个月吐血整理的几百G的资源,免费分享!....>>>
/* *搜索数据库当前用户的所有表,查出所有含date和time名称, *并且是number(14)类型的字段的日期部分改为当前日期 */ declare type tcur is ref cursor; --定义游标类型 columnsCur tcur; --定义表的字段游标 sTName varchar(30);--存储表名 sCName varchar(30);--存储字段名 nCurrentTime number(14); --存储当前日期 updstr varchar(900); begin --获取当前日期YYYYMMDD select to_number(to_char(sysdate, 'YYYYMMDD') || '000000') into nCurrentTime from dual; --从oracle系统表获取包含数字日期形式的字段名和对应的表名 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%'); --根据获得的表名和字段名把目前的时间更新为当前日期,时间保持不变 loop fetch columnsCur into sTName, sCName; exit when columnsCur%notfound; begin --执行更新 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 --如果发生错误,打印出执行的sql when others then dbms_output.put_line('Error:' || updstr); end; end loop; commit; end;