最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

批量更新表字段日期值的存储过程

来源:动视网 责编:小采 时间:2020-11-09 16:19:37
文档

批量更新表字段日期值的存储过程

批量更新表字段日期值的存储过程:今天由于测试一个报表,必须要当天的数据,可我昨天刚测过,数据还在库里,于是想偷个懒,手工修改时间字段为今天的日期,改了不到1分钟,发现表太多了,而且记录时间的字段每个表还不止一个,不如用程序来做。于是写了下面的这个存储过程,哈哈,好用 无 /
推荐度:
导读批量更新表字段日期值的存储过程:今天由于测试一个报表,必须要当天的数据,可我昨天刚测过,数据还在库里,于是想偷个懒,手工修改时间字段为今天的日期,改了不到1分钟,发现表太多了,而且记录时间的字段每个表还不止一个,不如用程序来做。于是写了下面的这个存储过程,哈哈,好用 无 /


今天由于测试一个报表,必须要当天的数据,可我昨天刚测过,数据还在库里,于是想偷个懒,手工修改时间字段为今天的日期,改了不到1分钟,发现表太多了,而且记录时间的字段每个表还不止一个,不如用程序来做。于是写了下面的这个存储过程,哈哈,好用 无 /*

今天由于测试一个报表,必须要当天的数据,可我昨天刚测过,数据还在库里,于是想偷个懒,手工修改时间字段为今天的日期,改了不到1分钟,发现表太多了,而且记录时间的字段每个表还不止一个,不如用程序来做。于是写了下面的这个存储过程,哈哈,好用 <无> $velocityCount-->
/*
 *搜索数据库当前用户的所有表,查出所有含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;

文档

批量更新表字段日期值的存储过程

批量更新表字段日期值的存储过程:今天由于测试一个报表,必须要当天的数据,可我昨天刚测过,数据还在库里,于是想偷个懒,手工修改时间字段为今天的日期,改了不到1分钟,发现表太多了,而且记录时间的字段每个表还不止一个,不如用程序来做。于是写了下面的这个存储过程,哈哈,好用 无 /
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top