本文介绍了每个ID仅返回最近的条目的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在Firebird 2.5-DB上运行此SQL脚本:

I'm running this SQL script on my Firebird 2.5-DB:

SELECT aktivitaet.creationdatetime,
(select STRINGPROPVALUE from PROPERTY WHERE PROPERTYNAME LIKE 'GlobalDokPfad') as basispfad,
aktivitaet.pfad,
cast(rechnung.datum as date),
rechnung.nummer,
projekt.code,
cast(rechnung.verrtotal as numeric(10,2)),
projekt.betreffend
FROM rechnung
INNER JOIN aktivitaetenlink ON rechnung.bold_id=aktivitaetenlink.eintraege
INNER JOIN aktivitaet ON aktivitaetenlink.aktivitaeten=aktivitaet.bold_id
Left JOIN projekt ON aktivitaet.projekt=projekt.bold_id
where rechnung.datum >= '01.01.2013' and rechnung.verrechnet=1 and aktivitaet.typ=15104
order by rechnung.nummer, aktivitaet.creationdatetime DESC;

它向我返回此结果:

CREATIONDATETIME,BASISPFAD,PFAD,CAST,NUMMER,CODE,CAST,BETREFFEND
"14.05.2014 16:53:25";"C:\Daten\Demo\Dokumente";"C:\Daten\Demo\Dokumente\Comte AG,Biel-Bienne\100027_2.doc";"18.12.2014 00:00:00";"100027";;"9491.0499999999993";
"14.05.2014 16:53:01";"C:\Daten\Demo\Dokumente";"C:\Daten\Demo\Dokumente\Comte AG, Biel-Bienne\100027.doc";"18.12.2014 00:00:00";"100027";;"9491.0499999999993";
"17.10.2014 14:06:08";"C:\Daten\Demo\Dokumente";"C:\Daten\Demo\Dokumente\Baumann GmbH, Luzern\100031.doc";"17.10.2014 00:00:00";"100031";;"842.39999999999998";
"16.04.2015 09:51:03";"C:\Daten\Demo\Dokumente";"C:\Daten\Demo\Dokumente\Comte AG, Biel-Bienne\100033.doc";"01.04.2015 00:00:00";"100033";;"1080012.05";
"01.04.2015 16:47:58";"C:\Daten\Demo\Dokumente";"C:\Daten\Dokumente\100033.doc";"01.04.2015 00:00:00";"100033";"COMTE AG";"1080012.05";"Treuhand"
"15.04.2015 09:24:46";"C:\Daten\Demo\Dokumente";"100035.doc";"15.04.2015 00:00:00";"100035";;"3240.";

我的问题:

如果存在2条具有相同rechnung.nummer(即1000033/1000027)的记录,则结果中将仅包含一条记录(具有最后aktivitaet.creationdatetime的一条记录).

If there exist 2 records with the same rechnung.nummer (i.e 1000033 / 1000027), only one record (the one with the last aktivitaet.creationdatetime) should be in the result.

推荐答案

当遇到来自联接的多个结果并且您要匹配最新日期的行时,联接条件中的相关子查询是我发现的一个子查询编写起来很简单,执行起来也很快:

When faced with multiple results from a join and you want to match the most recently dated row, a correlated subquery in the join criteria is one I have found to be quite simple to write and quite fast in execution:

...
JOIN    aktivitaet  a
    ON  a.bold_id = al.aktivitaeten
    AND a.creationdatetime =(
        SELECT  Max( creationdatetime )
        FROM    aktivitaet
        WHERE   bold_id = a.bold_id )
...

这篇关于每个ID仅返回最近的条目的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

09-05 16:04
查看更多