为什么在缩小列和仅获取第一行时会产生不同的结果?

 表发给上完善 发布于 2022-12-29 17:21

我在DB2中运行两个查询

SELECT * from mrptable FETCH FIRST ROW ONLY
--result for mrpcolumn = 1150131

SELECT mrpcolumn FROM mrptable FETCH FIRST ROW ONLY
--result for mrpcolumn = 0

为什么这两个结果会有所不同?

1 个回答
  • 任何order by一个查询都没有子句,因此结果集排序是不确定的.您甚至可以运行两次相同的查询并获得不同的结果.

    结果集的顺序不同的原因有很多.最有可能的是你有一个索引mrpcolumn.此索引涵盖第二个查询,因此查询可以使用索引获取一行.

    第一个是数据页.

    另一个原因是在并行环境中执行,其中不确定哪个线程/进程返回第一个值.

    使用fetch first条款时,通常应该使用order by.

    2022-12-29 17:24 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有