select返回记录的顺序[5]

[入库:2005年8月18日] [更新:2007年3月24日]

本文简介:选择自 youbo2004 的 blog

rowid的顺序与记录行存储的“物理序”一致。在没有索引情况下,select作全表扫描,是按“物理序”,此时select 返回记录按“物理序”最快。

2.         对于已经插入的记录其rowid不会发生变化。

如果全表扫描方式下,直接使用rownum作为选择条件,根据结论1,两次得到的记录可能是不一样的。如果sql有时间条件或其他条件作为sql语句辅助的筛选(排出当前插入的值),那么再用rownum作为选择条件,则返回的记录及记录的顺序均是一样的。

结论2的特性可用于某些日志表的清除-备份机制中。对于某些日志表为了提高insert性能,可能没有索引,并且在存储过程中对这些日志表进行清除和备份。利用insert into select 先将部分记录选入到备份表中,再用delete语句删除日志表中的记录。通过rownum来控制操作的行数,避免回滚段问题,通过时间条件来实施结论2,保证记录一致。

2.2按索引扫描

对于一段范围的按索引选择,在oracle内部表现为索引叶节点的扫描,索引叶节点通常已经排序并且叶节点之间存在指针,便于扫描。由于此时select按索引扫描表,因此返回的记录就按“索引序”排列。

利用上述特征,对于按索引扫描可以有以下的应用方式:

1.通过索引可以使返回记录事先排序。

本文关键:select返回记录的顺序
  相关方案
Google
 

本站最佳浏览方式为 分辨率 1024x768 IE 6.0(或更高版本的 IE浏览器)

go top