Ich weiß nicht, ob diese Lösung schön ist... Aber soweit ich sie testen konnte, funktioniert sie richtig.
Code: Alles auswählen
SELECT "Kunden".* FROM "Kunden" LEFT OUTER JOIN (
SELECT "ID", "ORG", "Abschlussgrund", "Wiedervorlage" FROM "Protokoll",
( SELECT "ORG", MAX( "Timestamp" ) AS "MTS" FROM "Protokoll" GROUP BY "ORG" ) AS "vTop"
WHERE "Protokoll"."ORG" = "vTop"."ORG" AND "Protokoll"."Timestamp" = "vTop"."MTS" AND ( ( "Abschlussgrund" = 'WV' AND "Wiedervorlage" < NOW( ) )
OR ( "Abschlussgrund" = 'NE' AND DATEDIFF( 'mi', "Timestamp", CURRENT_TIMESTAMP ) > 120 )
OR "Abschlussgrund" IS NULL
OR "Abschlussgrund" = '' )) "PROT" ON "PROT"."ORG" = "Kunden"."ID" WHERE "Kunden"."ID" = "PROT"."ORG" OR "Kunden"."ID" NOT IN ( SELECT DISTINCT "ORG" FROM "Protokoll" )
ORDER BY "PROT"."Abschlussgrund" DESC, "Wiedervorlage" ASC
Jetzt bleibt mir für das Formular einstweilen nur noch eine Frage offen:
Du hast mir ja den Button "Neues Protokoll" mit der Aktion "Neuer Datensatz" für das Unterformular belegt. Kann ich diese Aktion auch beim Aktualisieren des Formulars sofort ausführen? Also wenn ich den Button "Neuer Datensatz" klicke, der ja mit der Aktion "Formular aktualisieren" belegt ist, dann soll gleichzeitig im aktualisierten Formular ein neuer Datensatz im Unterformular erzeugt werden.
[edit]
Zum zweiten Problem hab ich
http://de.openoffice.info/viewtopic.php?t=54440#p207295 gefunden. Aber das liefert nur eine Fehlermeldung. Mit welchem Ereignis müsste ich dieses Makro verbinden?
[/edit]
lg scientific