设为首页
收藏本站
开启辅助访问
切换到窄版
登录
立即注册
中问网首页
我的收藏
站长博客
搜索
搜索
本版
帖子
用户
第一问答网
»
论坛
›
中问网
›
问答
›
一个奇怪的sql
返回列表
发新帖
一个奇怪的sql
[复制链接]
11
|
4
|
2011-11-1 16:23:26
|
显示全部楼层
|
阅读模式
本帖最后由 bigsea1017 于 2012-2-27 11:55 编辑
select * from(SELECT locationName,'B13010101' a1 FROM VIEW_AVAILABLEOUTSTORESTOCK STKWHERE STK.LATLEVEL > 1AND stk.subitemid= 416284AND NOT EXISTS(SELECT 1FROM tab_sms_command tscWHERE tsc.source =stk.locationName)AND NOT EXISTS(SELECT 1FROM tab_sub_warehouse tswWHERE tsw.subid =stk.subwarehouseidAND tsw.basewarehouseid= (SELECT basewarehouseid FROM tab_base_warehouse WHERE code = 'W02'))ORDER BY STK.INDATE,STK.STOCKID) WHERE rownum=1;如果没有外层的select,只查询内层数据有记录出现,添加了外层的rownum=1就什么记录都没有,然后像下面这样改写就有记录了,不知道什么原因呀??不是所有都没有记录,将AND stk.subitemid= 416284值换一个有时候就有记录,什么原因呢?有谁遇到过吗?
改写为:select * from (SELECT rownum col,locationName,'B13010101' a1 FROM VIEW_AVAILABLEOUTSTORESTOCK STKWHERE STK.LATLEVEL > 1AND stk.subitemid= 416284AND NOT EXISTS(SELECT 1FROM tab_sms_command tscWHERE tsc.source=stk.locationName)AND NOT EXISTS(SELECT 1FROM tab_sub_warehouse tswWHERE tsw.subid=stk.subwarehouseidAND tsw.basewarehouseid=(SELECT basewarehouseid FROM tab_base_warehouse WHERE code = 'W02'))ORDER BY STK.INDATE,STK.STOCKID) WHERE col=1;
回复
使用道具
举报
千问
|
2011-11-1 16:23:26
|
显示全部楼层
<=1?
回复
使用道具
举报
千问
|
2011-11-1 16:23:26
|
显示全部楼层
〇〇 发表于 2012-2-27 12:00
<=1 和<2都不可以,必需在内层添加一个行列。
但是对于有些数据就不需要这样,直接rownum=1限制取order by之后的第一行就可以的。
回复
使用道具
举报
千问
|
2011-11-1 16:23:26
|
显示全部楼层
看执行计划,谓词是否被推进了子查询
回复
使用道具
举报
千问
|
2011-11-1 16:23:26
|
显示全部楼层
两个执行计划如附件,没看出来有什么不同。有些条件不一样,但是整体执行计划差不多的。
回复
使用道具
举报
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
千问
主题
0
回帖
4882万
积分
论坛元老
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
积分
48824836
加好友
发消息
回复楼主
返回列表
问答
热门排行