这个问题在项目中是一个很重要的细节,具体有两种处理方式,主要取决于这个表是否需要进行数据交换,以及这个时间字段如何使用,具体举两个例子吧:
专注于为中小企业提供成都网站建设、网站制作服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业弋江免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了超过千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
一、使用varchar2型
1、如果这张表对时间的精度要求不高,比如只是到日。
2、该表需要经常与其他表进行数据交互,比较,查询,并且其他表的时间精度不高于日(比如日、月、季度)
3、存储大量数据用于统计分析,如本期、同期,累计值等。
存储的时候需要格式化,例如:to_char(sysdate,'yyyy-mm-dd');
二、使用date型。
1、对时间精度要求较高,比如到秒;
2、需要与其他表做数据交互,更偏重于”准实时“交互,比如每15秒同步一次数据;
3、不用于统计分析(这点很重要,需要统计分析的话,强烈不建议使用date型);
4、该表数据不做物理删除(删除时只更新标志位和删除时间);
以上我这几年的实际项目经验,希望可以帮到你。
update b to_date("20190101 09:09:02");
日期格式需要转换,百度一下很多写法。
更改格式对不对,需要先用查看语句试一下,有时候会报错。
select to_date("20190101 09:09:02") from dual;
很简单的。
我感觉你应该是不知道怎么写每月和每年吧。其实很简单,把你下次时间的字符串拿出来看下就行。下面是代码。
DECLARE
I4 INTEGER;I5 INTEGER;
BEGIN
--每月5号中午12点
DBMS_JOB.SUBMIT(I4,'YOUR PROC;',SYSDATE,'TRUNC(SYSDATE, ''MM'') + 4 + 12 / 24');
--每年1月10号中午12点
DBMS_JOB.SUBMIT(I5,'YOUR PROC;',SYSDATE,'TRUNC(SYSDATE, 'Y') + 9 + 12 / 24');
COMMIT;
END;
每天晚上6点到第二天早上8点的数据?
按照24小时制,那可以拆分为:18~24;1~8
试试这个:
select * from tbl c
where
( to_char(c.date, 'hh24:mi:ss') = '18:00:00' and to_char(c.date, 'hh24:mi:ss') = '24:00:00')
or
( to_char(c.date, 'hh24:mi:ss') = '01:00:00' and to_char(c.date, 'hh24:mi:ss') = '08:00:00')
oracle job 时间每五分钟执行:
begin
sys.dbms_job.submit(job = :job,
what = '一个存储过程;',
Interval =TRUNC(sysdate,'mi') + 5/ (24*60));
commit;
end;
其中:如果改成TRUNC(sysdate,'mi')+ 10/ (24*60) 就是每10分钟执行次。每秒钟执行次:Interval = sysdate+ 1/(24 * 60 * 60)。如果改成sysdate + 10/(24 *60 * 60)就是10秒钟执行次。
使用dbms_job.submit方法过程,这个过程有五个参数:job、what、next_date、interval与no_parse:
1、job参数是输出参数,由submit()过程返回的binary_ineger,这个值用来唯一标识一个工作。一般定义一个变量接收,可以去user_jobs视图查询job值。
2、what参数是将被执行的PL/SQL代码块,存储过程名称等。
3、next_date参数指识何时将运行这个工作。
4、interval参数何时这个工作将被重执行。
5、no_parse参数指示此工作在提交时或执行时是否应进行语法分析——true,默认值false。指示此PL/SQL代码在它第一次执行时应进行语法分析,而FALSE指示本PL/SQL代码应立即进行语法分析。
扩展资料:
1、每天定时执行
例如:每天的凌晨1点执行
Interval =TRUNC(sysdate) + 1 +1/ (24)
2、每周定时执行
例如:每周一凌晨1点执行:
Interval =TRUNC(next_day(sysdate,'星期一'))+1/24
3、每月定时执行
例如:每月1日凌晨1点执行:
Interval=TRUNC(LAST_DAY(SYSDATE))+1+1/24
4、每季度定时执行
例如每季度的第一天凌晨1点执行:
Interval =TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 1/24
参考资料来源:百度百科-Oracle系统
参考资料来源:百度百科-Oracle PL/SQL从入门到精通
1、创建测试表,
create table test_date(id number, times date);
2、插入测试数据
insert into test_date select level, sysdate-level/24/60 t from dual connect by level = 100;
commit;
3、查询表中数据,select t.* from test_date t;
4、编写sql,获取加5分钟大于等于当前系统时间的记录; select t.* from test_date t where times+5/24/60=sysdate;