前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle 多表连接查询取最近一条记录

Oracle 多表连接查询取最近一条记录

作者头像
斯文的程序
发布2019-11-07 17:32:42
2.6K0
发布2019-11-07 17:32:42
举报
文章被收录于专栏:带你回家带你回家带你回家
SELECT PCC.CUSTNO custNo,T.PERSON_NO,T.CREATNAME visitorName,to_char(T.VISIT_TIME,'yyyy-MM-dd HH24:mi:ss') visitDate ,T.VISIT_CONTENT vistTxt,PCC.INVNM custName,PCC.BALANCE_TOTAL,PCC.BALANCE_PRODUCT FROM PRSP_CRM_CUSTINFO PCC
		LEFT JOIN
		(SELECT a.*,row_number() over(partition by a.PERSON_NO ORDER BY a.VISIT_TIME DESC) as rn FROM 
		(SELECT 
	       PCV.VISIT_CONTENT,
	       PCV.VISIT_TIME,
	       PPD.INVNM CREATNAME,
		   PCMP.PERSON_NO
        FROM 
			PRSP_CRM_MEETANDACTITY_PERSON PCMP 
		LEFT JOIN 
			PRSP_CRM_VISIT PCV 
		ON 
			PCV.SERIAL_VISIT_NO=PCMP.SERIAL_REFREN_NO 
		LEFT JOIN 
			PRSP_CRM_CUSTINFO PPD 
		ON 
			PPD.CUSTNO=PCV.CREATE_NO
		WHERE PCMP.MEET_TYPE='1' AND PCMP.PERSON_TYPE='2' AND PCMP.DELETE_FLG='0') a ) T
		ON PCC.CUSTNO=T.PERSON_NO and t.rn=1
		where 1=1 

1.首先 写一个 连接查询语句: 比如有时间的表排序

2、 通过这个函数 select a.* row_number() over(partition by 分组的字段 order by 排序时间 desc) as rn from (结果集) a

2. 显示的结果

这样就会把第一条第二条进行排序。。 我们 写一个条件 rn=1 这样就是取最近一条了。。

最后去关联你想要的表就好了。。

遇到的问题:

如果其他时间为空 那么他的排序就是 为空的时间排再前面 如何解决呢?

这里使用上面的办法解决。。。

效果图:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档