ITPUB论坛-中国最专业的IT技术社区

 
 注册
热搜:
查看: 651|回复: 6

如何改写这段代码?

[复制链接]
论坛徽章:
304
奥迪
日期:2013-07-29 13:45:59红旗
日期:2014-02-07 10:47:20路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14
跳转到指定楼层
1#
发表于 2017-12-4 11:12 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
ORACLE 11204

SELECT * FROM
FROM TAB_20171204
WHERE FLOTID IN (SELECT MIN(T1.FLOTID) FLOTID FROM TAB_20171204 T1
                 INNER JOIN (SELECT FMATERIALID, FNUMBER, MIN(FBIZTYPE) FBIZTYPE FROM TAB_20171204  GROUP BY FMATERIALID, FNUMBER) T2
                 ON ( (T1.FMATERIALID = T2.FMATERIALID AND T1.FNUMBER = T2.FNUMBER) AND T1.FBIZTYPE = T2.FBIZTYPE ) GROUP BY T1.FMATERIALID, T1.FNUMBER)

如何改成最优写法?

论坛徽章:
304
奥迪
日期:2013-07-29 13:45:59红旗
日期:2014-02-07 10:47:20路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14
2#
 楼主| 发表于 2017-12-4 11:16 | 只看该作者
这样改写,两语句是不是等价的?

SELECT * FROM
(select T1.*, rank() over(T1.FMATERIALID, T1.FNUMBER order by flotid asc, FBIZTYPE asc) seq FROM TAB_20171204  T1 where T1.FMATERIALID is not null and T1.FNUMBER is not null) where seq=1

使用道具 举报

回复
认证徽章
论坛徽章:
168
SQL数据库编程大师
日期:2016-01-13 10:30:43SQL极客
日期:2013-12-09 14:13:35SQL大赛参与纪念
日期:2013-12-06 14:03:45最佳人气徽章
日期:2015-03-19 09:44:03现任管理团队成员
日期:2015-08-26 02:10:00秀才
日期:2015-07-28 09:12:12举人
日期:2015-07-13 15:30:15进士
日期:2015-07-28 09:12:58探花
日期:2015-07-28 09:12:58榜眼
日期:2015-08-18 09:48:03
3#
发表于 2017-12-4 18:37 | 只看该作者
感觉原sql中间写了一段废话。

使用道具 举报

回复
论坛徽章:
480
榜眼
日期:2015-09-09 10:34:21秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12状元
日期:2015-11-23 10:04:09举人
日期:2015-11-23 10:04:09
4#
发表于 2017-12-4 22:28 | 只看该作者
2楼语法错误。即使加上PARTITION BY也不等价。1楼的WHERE里面只有FLOTID,怀疑是写错了,应该是三个列,(FMATERIALID, FNUMBER, FLOTID)
所以先搞清楚需求再说。

使用道具 举报

回复
论坛徽章:
304
奥迪
日期:2013-07-29 13:45:59红旗
日期:2014-02-07 10:47:20路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14
5#
 楼主| 发表于 2017-12-5 17:07 | 只看该作者
newkid 发表于 2017-12-4 22:28
2楼语法错误。即使加上PARTITION BY也不等价。1楼的WHERE里面只有FLOTID,怀疑是写错了,应该是三个列,(FM ...

版主英明,若只 floatid,那 in 子查询里前后数据会矛盾,作无用功,没意义,只有用上这3个字段,过滤出来的数据才有意义,

使用道具 举报

回复
认证徽章
论坛徽章:
168
SQL数据库编程大师
日期:2016-01-13 10:30:43SQL极客
日期:2013-12-09 14:13:35SQL大赛参与纪念
日期:2013-12-06 14:03:45最佳人气徽章
日期:2015-03-19 09:44:03现任管理团队成员
日期:2015-08-26 02:10:00秀才
日期:2015-07-28 09:12:12举人
日期:2015-07-13 15:30:15进士
日期:2015-07-28 09:12:58探花
日期:2015-07-28 09:12:58榜眼
日期:2015-08-18 09:48:03
6#
发表于 2017-12-5 20:39 | 只看该作者
newkid 发表于 2017-12-4 22:28
2楼语法错误。即使加上PARTITION BY也不等价。1楼的WHERE里面只有FLOTID,怀疑是写错了,应该是三个列,(FM ...

如果三个列都加上的话,我觉得 over里面的FBIZTYPE asc可以不用。

使用道具 举报

回复
论坛徽章:
480
榜眼
日期:2015-09-09 10:34:21秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12秀才
日期:2015-11-23 10:03:12状元
日期:2015-11-23 10:04:09举人
日期:2015-11-23 10:04:09
7#
发表于 2017-12-5 23:34 | 只看该作者
Naldonado 发表于 2017-12-5 20:39
如果三个列都加上的话,我觉得 over里面的FBIZTYPE asc可以不用。

不是不用,是他把优先级搞错了,应该是
order by FBIZTYPE asc, flotid asc

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档 |
  | | |
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 网站律师 隐私政策 知识产权声明
 北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表