scl*_*son 3 sql database db2 ibm-midrange
我在DB2中运行两个查询
SELECT * from mrptable FETCH FIRST ROW ONLY
--result for mrpcolumn = 1150131
SELECT mrpcolumn FROM mrptable FETCH FIRST ROW ONLY
--result for mrpcolumn = 0
Run Code Online (Sandbox Code Playgroud)
为什么这两个结果会有所不同?
任何order by一个查询都没有子句,因此结果集排序是不确定的.您甚至可以运行两次相同的查询并获得不同的结果.
结果集的顺序不同的原因有很多.最有可能的是你有一个索引mrpcolumn.此索引涵盖第二个查询,因此查询可以使用索引获取一行.
第一个是数据页.
另一个原因是在并行环境中执行,其中不确定哪个线程/进程返回第一个值.
使用fetch first条款时,通常应该使用order by.
| 归档时间: |
|
| 查看次数: |
70 次 |
| 最近记录: |