批量更新表字段日期值的存储进程
发布时间:2020-12-24 18:25:12 所属栏目:编程 来源:网络整理
导读:本日PHP站长网 52php.cn把网络自互联网的代码分享给各人,仅供参考。 /* *搜刮数据库当前用户的全部表,查出全部含date和time名称, *而且是number(14)范例的字段的日期部门改为当前日期 */declare type tcur is ref curs
以下代码由PHP站长网 52php.cn网络自互联网 此刻PHP站长网小编把它分享给各人,仅供参考 /* *搜刮数据库当前用户的全部表,查出全部含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; 以上内容由PHP站长网【52php.cn】网络清算供各人参考研究 假如以上内容对您有辅佐,接待保藏、点赞、保举、分享。 (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |