我想在数据表中插入一些日期数据。分别有year week start_date end_date 都代表着是什么年份。在这一年里的第几个周期。开始时间是几月几号 到几月几号(例:2009 1 2008-12-28 2009-1-3)因为要插入一年的数据如果一条条插入的话好麻烦。
我还是个Oracle的新手,请大侠们教教。。听说用存储过程可以的。但不知道怎么写~~~在这先谢谢啦!
看你举例的数据是要写周的数据
可以这样
insert into table
as select '2009' year,rownum week,to_date('2008-12-28','yyyy-mm-dd')+(rownum-1)*7 start_date,
to_date('2008-12-28','yyyy-mm-dd')+rownum*7-1 end_date
from dual
connect by rownum <=52
不一定要写存储过程
何波的正确,但是值能插入一年内的数据,如果大量插入的话,语句就需要更改
SQL code:
select to_char(to_date('2009-1-3','yyyy-mm-dd')+(rownum-1)*7,'yyyy')year,
to_number(to_char(to_date('2009-1-3','yyyy-mm-dd')+(rownum-1)*7,'iw'))week,
to_date('2008-12-28','yyyy-mm-dd')+(rownum-1)*7 startdate,
to_date('2009-1-3','yyyy-mm-dd')+(rownum-1)*7 enddate from dual
connect by rownum<1000
狂狼的,也是只能插入数年之内的数据。
最好写一个存储过程,留一个参数来传入年数值,这样就搞定了。
SQL code:
create or replace procedure
我安装一台redhat linux5+oracle 10g的服务器,笔记本(XP系统)安装了oracle 10g客户端,结果老是出12560的错误,请高手指点一二,
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dpor ......