批量更新表字段日期值的存储过程
发布时间:2020-05-23 10:10:16 所属栏目:MySql 来源:互联网
导读:批量更新表字段日期值的存储过程
|
下面是脚本之家 jb51.cc 通过网络收集整理的代码片段。 脚本之家小编现在分享给大家,也给大家做个参考。 /*
*搜索数据库当前用户的所有表,查出所有含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;
以上是脚本之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。 如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
