Hallo zusammen,
ich habe mal wieder mit Schwierigkeiten in einem meiner Makros zu kämpfen...
Die Abfrage selbst zielt auf eine PostGreSQL DB, die per ODBC Verbindung angebunden ist. Nun lese ich aus einer bestimmten Tabelle in der DB Namen aus, die in ein Dropdownmenü ausgegeben werden.
Die Namen können z.B. D--000XXX0007 oder AR-000XXX0008 heißen.
Den ausgewählten Namen lasse ich per getSelectedItem Befehl in eine Variable speichern. Mit Hilfe dieser Variable soll nun eine zweite SQL Abfrage funktionieren, die mir aber Probleme bereitet.
"SELECT ""data_1"",""data_2"",""data_3"" FROM ""daten"" WHERE ""data_4""=" & gewname(i) & ""
Der im Dropdownmenü gewählte Name wird vorher in die Variable gewname gespeichert.
Nun lasse ich die Abfrage laufen und er gibt mir einen Syntaxfehler aus. Wenn zwischen dem ersten Buchstaben und den ersten Zahlen -- stehen bricht er mit der Meldung ab, dass die Spalte D (um das Beispiel von oben zu nehmen) nicht existiert. Sobald nur ein - zwischen den ersten Buchstaben und ersten Zahlen steht bricht er mit der Meldung ab "Syntaxfehler bei xxx0008".
Ich nehme an, dass der Name nicht komplett "genommen" wird in der Abfrage, sondern immer nur Bruchteile. Wie muss ich die Variable nun "einpacken", damit er den kompletten Begriff nutzt?
Viele Grüße
Kenji
🙏 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!🍀
>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗
Marko Abfrage auf eine PostGre SQL DB
Re: Marko Abfrage auf eine PostGre SQL DB
Das mit den Abfrage-Bruchteilen könnte sein - zumindest könnten die 2 Bindestriche schuld daran sein, dass Dein Code geteilt wird. Denn (zumindest bei MySQL) sind 2 Bindestriche das Zeichen für einen Kommentar im SQL-Code. Evtl musst Du die Zeichen escapen. Normalerweise macht man das mit einem \ vor dem -
g
2008 LucidL./MaverickM./WinXP LibreOffice 3.3.2 > 02/13 LinuxMint13/Xubuntu > 09/13 Debian Wheezy+LO3.5.4.2 > 01/15 Debian Jessie KDE+LO4.3.3.2/Mint17 openbox auf USB+LO4.2.8.2 > 03/16 ArchLin & LO5.1+ff > 02/18 Kubuntu
2008 LucidL./MaverickM./WinXP LibreOffice 3.3.2 > 02/13 LinuxMint13/Xubuntu > 09/13 Debian Wheezy+LO3.5.4.2 > 01/15 Debian Jessie KDE+LO4.3.3.2/Mint17 openbox auf USB+LO4.2.8.2 > 03/16 ArchLin & LO5.1+ff > 02/18 Kubuntu
Re: Marko Abfrage auf eine PostGre SQL DB
... ausserdem vergleichst Du hier einen Text - der muss in Single-Quotes eingeschlossen sein, sonst wird angenommen dass es sich um Felder, Zahlen, Funktionen oder Variablen handelt:
... woraus sich Deine 2 Fehler erklären lassen:
AR-000XXX0008 bedeutet : Ergebnis von Spalte AR minus Spalte 000XXX0008 ... es gibt keine Spalte AR!
bzw:
D--000XXX0007 bedeutet : Ergebnis von Spalte D minus minus Spalte 000XXX0007 ... Syntaxfehler!
Code: Alles auswählen
"SELECT ""data_1"",""data_2"",""data_3"" FROM ""daten"" WHERE ""data_4""= '" & gewname(i) & "'"
ergibt:
SELECT "data_1","data_2","data_3" FROM "daten" WHERE "data_4"= 'D--000XXX0007'
"SELECT ""data_1"",""data_2"",""data_3"" FROM ""daten"" WHERE ""data_4""= " & gewname(i) & ""
ergibt:
SELECT "data_1","data_2","data_3" FROM "daten" WHERE "data_4"= D--000XXX0007
oder:
SELECT "data_1","data_2","data_3" FROM "daten" WHERE "data_4"= AR-000XXX0008
AR-000XXX0008 bedeutet : Ergebnis von Spalte AR minus Spalte 000XXX0008 ... es gibt keine Spalte AR!
bzw:
D--000XXX0007 bedeutet : Ergebnis von Spalte D minus minus Spalte 000XXX0007 ... Syntaxfehler!
g
2008 LucidL./MaverickM./WinXP LibreOffice 3.3.2 > 02/13 LinuxMint13/Xubuntu > 09/13 Debian Wheezy+LO3.5.4.2 > 01/15 Debian Jessie KDE+LO4.3.3.2/Mint17 openbox auf USB+LO4.2.8.2 > 03/16 ArchLin & LO5.1+ff > 02/18 Kubuntu
2008 LucidL./MaverickM./WinXP LibreOffice 3.3.2 > 02/13 LinuxMint13/Xubuntu > 09/13 Debian Wheezy+LO3.5.4.2 > 01/15 Debian Jessie KDE+LO4.3.3.2/Mint17 openbox auf USB+LO4.2.8.2 > 03/16 ArchLin & LO5.1+ff > 02/18 Kubuntu
Re: Marko Abfrage auf eine PostGre SQL DB
Hallo,
vielen Dank für die Info. Hat wunderbar funktioniert...
Grüße
Kenji
vielen Dank für die Info. Hat wunderbar funktioniert...
Grüße
Kenji
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.