Chinaunix首页 | 论坛 | 博客
  • 博客访问: 666267
  • 博文数量: 168
  • 博客积分: 2928
  • 博客等级: 中校
  • 技术积分: 1904
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-04 09:56
文章分类

全部博文(168)

文章存档

2010年(168)

我的朋友

分类: Oracle

2010-05-20 10:33:05

需求:如何简单的在一张表中瞬间初始化好一连续,规则为时间间隔为的的DATE类型数据。
我们使用技术来完成这个貌似很“复杂”的需求。

1.创建测试表T,仅包含一个时间字段TIME
sec@ora10g> create table t (time date);

Table created.

2.先初始化一条时间点开始数据
sec@ora10g> insert into t(time) values (to_date('20100514','yyyymmdd'));

1 row created.

3.我们使用 by方法来巧妙的完成这个需求
sec@ora10g> insert into t(time) select to_date('20100514','yyyymmdd')+level/24/60 from t connect by rownum <=10;

10 rows created.

sec@ora10g> commit;

Commit complete.

4.激动人心的结果
sec@ora10g> select * from t order by time;

TIME
-------------------
2010-05-13 00:00:00
2010-05-13 00:01:00
2010-05-13 00:02:00
2010-05-13 00:03:00
2010-05-13 00:04:00
2010-05-13 00:05:00
2010-05-13 00:06:00
2010-05-13 00:07:00
2010-05-13 00:08:00
2010-05-13 00:09:00
2010-05-13 00:10:00

11 rows selected.

5.小结
使用层次查询(CONNECT BY)可以方便的完成批量数据创建的任务,在具体需求中如能灵活的使用层次查询技术,将给我们带来非常大的便利。
如果想一次性初始化一小时的数据,仅需要将“connect by rownum <=10”修改为“connect by rownum <=1440”即可,因为一小时包含1440分钟。

Good luck.


10.05.13

-- The End --
阅读(1028) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~