🙏 Helfen Sie jetzt mit, unser LibreOffice Forum zu erhalten! 🙏
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀

❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗

Protokoll zu Anrufliste

Base ermöglicht es Ihnen, Ihre Daten in einer Datenbank direkt mit LibreOffice zu bearbeiten.
F3K Total
* LO-Experte *
Beiträge: 2501
Registriert: So 10. Apr 2011, 10:10

Re: Protokoll zu Anrufliste

Beitrag von F3K Total » Mi 1. Mai 2013, 22:31

Moin,
scientific hat geschrieben:Mit einem "ORDER BY" wirds so noch nicht gehen.
Wenn Du statt "WV", "NE" usw. Integer Werte ins Protokoll schreibst, kannst du danach sortieren.
Im Beispiel anbei habe ich eine Tabelle Abschlussgründe zugefügt, in der deine gewünschte Reihenfolge durch die sortierung nach dem o.a Integer Wert erreicht wir.
Deine Kunden stehen jetzt also in der richtigen Reihenfolge da.
Erst die WV dann die NE dann die neuen.
Gruß R
Dateianhänge
KundendatenbankNeu.zip
(16.29 KiB) 159-mal heruntergeladen
Windows 11: AOO, LO Linux Mint: AOO, LO

scientific
Beiträge: 131
Registriert: Do 25. Apr 2013, 17:27

Re: Protokoll zu Anrufliste

Beitrag von scientific » Mi 1. Mai 2013, 23:21

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

scientific
Beiträge: 131
Registriert: Do 25. Apr 2013, 17:27

Re: Protokoll zu Anrufliste

Beitrag von scientific » Do 2. Mai 2013, 12:13

War nur eine "Kleinigkeit"
Hier das für dieses Formular mit Unterformular passende Script, welches ich im Formular "Kunden" (erreichbar über den Formular-Navigator) dem Ereignis "Beim erneuten Laden" zugewiesen habe.

Code: Alles auswählen

SUB NEWREC

  oDrawPage = ThisComponent.getDrawPage()
  oForms = oDrawPage.getForms()
  oObj_1 = oForms.getByName("Kunden").getByName("Protokolle")
  
  oObj_1.moveToInsertRow()


END SUB
Jetzt funktioniert es.


An alle, die das LibreOffice-Forum gern nutzen und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten