❤️ Helfen Sie noch heute, unser LibreOffice Forum zu erhalten! ❤️
Unterstützen Sie das LibreOffice-Forum und helfen Sie uns, unser Ziel für 2025 zu erreichen!

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱


❤️ 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. 🤗

(gelöst) SQL-Abfrage mit mehreren Variablen

Base ermöglicht es Ihnen, Ihre Daten in einer Datenbank direkt mit LibreOffice zu bearbeiten.
Antworten
PeterF
Beiträge: 28
Registriert: Mi 15. Aug 2018, 09:30

(gelöst) SQL-Abfrage mit mehreren Variablen

Beitrag von PeterF » Di 18. Sep 2018, 12:31

Hallo Leute,

ich hab da wieder eine Frage, ehe ich einen ganzen Tag nach einer simplen Lösung suche:

Code: Alles auswählen

Sub Test_Anruf(scall)
	scaller = "0xxx03-123456"
	DatabaseContext = createUnoService("com.sun.star.sdb.DatabaseContext")
	oDatenquelle = Databasecontext.getByName("LaBella_Datenbank-test2")
	oDatVerb = oDatenquelle.getConnection("","")
	oStatement = oDatVerb.createStatement()
	msgBox scaller
	sSQL = "SELECT * FROM ""Kunden_Test"" WHERE ""TELEFON"" = scaller OR ""TELEFON2""  = scaller"
	oErgSet = oStatement.executeQuery(sSQL)
	oErgSet.Next
	msgBox oErgSet.getString(1) &" "& oErgSet.getString(2) &" "& oErgSet.getString(3)
End Sub
Das Makro soll bei einem ankommenden Anruf die zugehörige Adresse aus der Tabelle "Kunden_Test" auslesen.
Die Variable scaller habe ich probehalber eingeführt, damit ich nicht ständig meine FritzBox anrufen muß, die mir über den Anrufmonitor die Variable scall liefert. Also geht es letztlich um scall als Übergabeparameter.
Das Makro funktioniert, wenn ich bei einer Bedingung bleibe. Doch bei 2 oder mehr Bedingungen konnte ich bisher keine brauchbaren SQL-String erzeugen. Die folgenden Zeile hat einen Fehler:

Code: Alles auswählen

sSQL = "SELECT * FROM ""Kunden_Test"" WHERE ""TELEFON"" = scaller OR ""TELEFON2""  = scaller"
Das Aufräumen dieser Baustelle könnte mir an einer anderen Stelle die Programmierung wesentlich vereinfachen. (Habe mehrere Abfragen übereinandergestapelt, da ich keine bessere Lösung für das Verarbeiten von mehreren Variablen in einer SQL-Sentenz fand.)

Ich bin über jede Hilfe dankbar.

Gruß
Peter
Zuletzt geändert von PeterF am Di 18. Sep 2018, 13:05, insgesamt 1-mal geändert.

PeterF
Beiträge: 28
Registriert: Mi 15. Aug 2018, 09:30

Re: SQL-Abfrage mit Variablen

Beitrag von PeterF » Di 18. Sep 2018, 13:04

Hab sie schon - die Lösung:

Code: Alles auswählen

sSQL = "SELECT * FROM ""Kunden_Test"" WHERE (""TELEFON"" =" &"'" &scaller &"' OR ""TELEFON2"" =" &"'" &scaller &"')"
Bin halt mit den vielen Hochkommas durcheinander gekommen.

Entschuldigung.


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