❤️ 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. 🌱
>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗
Daten mit Basic aus Tabelle auslesen und schreiben
-
- Beiträge: 4
- Registriert: Sa 27. Jul 2019, 15:09
Daten mit Basic aus Tabelle auslesen und schreiben
Wer hilft mir bei folgendem Problem:
Ich erstelle eine Vereinsverwaltung in lo-base mit 2 Tabellen.
Tabelle1 enthält die Mitglieder, deren Monatsbeitrag und …....
Tabelle2 enthält Buchungen: monatliche Sollstellungen (der Monatsbeiträge) und Zahlungseingänge.
Die Zahlungseingänge werden per Hand als Gutschrift in die Tabelle2 gebucht.
PROBLEM:
Die Monatsbeitrag möchte ich als Sollstellung jeden Monat, mit Makro, für alle Mitglieder aus Tabelle1, in die Tabelle2 buchen.
Das Makro soll:
aus einem Formular heraus gestartet werden.
die Zal der Datensätze der Tabelle1 ermitteln.
in einer Schleife alle Datensätze aus Tabelle1 auslesen, Datenfelder bearbeiten und als Datensatz an Tabelle2 anhängen.
Wo finde ich ein Beispiel.
Gruß Löckenhoff
Ich erstelle eine Vereinsverwaltung in lo-base mit 2 Tabellen.
Tabelle1 enthält die Mitglieder, deren Monatsbeitrag und …....
Tabelle2 enthält Buchungen: monatliche Sollstellungen (der Monatsbeiträge) und Zahlungseingänge.
Die Zahlungseingänge werden per Hand als Gutschrift in die Tabelle2 gebucht.
PROBLEM:
Die Monatsbeitrag möchte ich als Sollstellung jeden Monat, mit Makro, für alle Mitglieder aus Tabelle1, in die Tabelle2 buchen.
Das Makro soll:
aus einem Formular heraus gestartet werden.
die Zal der Datensätze der Tabelle1 ermitteln.
in einer Schleife alle Datensätze aus Tabelle1 auslesen, Datenfelder bearbeiten und als Datensatz an Tabelle2 anhängen.
Wo finde ich ein Beispiel.
Gruß Löckenhoff
Re: Daten mit Basic aus Tabelle auslesen und schreiben
etwa so?
Code: Alles auswählen
insert into Buchungen
(ID_Buchungen, ID_Mitglied, Monatsbeitrag )
select
NULL, ID_Mitglied, Monatsbeitrag
from Mitglieder
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
-
- Beiträge: 4
- Registriert: Sa 27. Jul 2019, 15:09
Re: Daten mit Basic aus Tabelle auslesen und schreiben
Vielen Danke gogo,
mit dem SQL-Kode wird fast das erreich was mir vorschwebt.
Warum einfach wenn es auch umständlich geht. Um Basic in Base besser zu begreifen, möchte ich das ganze umständlich mit Basic lösen. Denn wenn ich die Feldinhalte in Basic-Variablen habe, fällt es mir leichter die Daten zu bearbeiten, Wie muss ich die Tabellen aus Basic heraus ansprechen?
So:
Datenquelle = ThisComponent.Parent.DataSource
Verbindung = Datenquelle.GetConnection("","")
SQL_Anweisung = Verbindung.createStatement()
geht es nicht.
Wie übernehme ich die Feldinhalte in Basic-Variablen?
mit dem SQL-Kode wird fast das erreich was mir vorschwebt.
Warum einfach wenn es auch umständlich geht. Um Basic in Base besser zu begreifen, möchte ich das ganze umständlich mit Basic lösen. Denn wenn ich die Feldinhalte in Basic-Variablen habe, fällt es mir leichter die Daten zu bearbeiten, Wie muss ich die Tabellen aus Basic heraus ansprechen?
So:
Datenquelle = ThisComponent.Parent.DataSource
Verbindung = Datenquelle.GetConnection("","")
SQL_Anweisung = Verbindung.createStatement()
geht es nicht.
Wie übernehme ich die Feldinhalte in Basic-Variablen?
Re: Daten mit Basic aus Tabelle auslesen und schreiben
Hallo Loeckenhoff,
an welcher Stelle geht das, was Du da andeutest, denn nicht?
Jetzt muss doch nur noch der SQL-Code kommen:
Die Maskierung mit Anführungszeichen sollten im Basic-Code für die interne Datenbank vorhanden sein.
Gruß
Robert
an welcher Stelle geht das, was Du da andeutest, denn nicht?
Code: Alles auswählen
Datenquelle = ThisComponent.Parent.DataSource
Verbindung = Datenquelle.GetConnection("","")
SQL_Anweisung = Verbindung.createStatement()
Code: Alles auswählen
stSql = "insert into ""Buchungen"" (""ID_Mitglied"", ""Monatsbeitrag"" ) (select ""ID_Mitglied"", ""Monatsbeitrag"" from ""Mitglieder"")"
SQL_Anweisung.executeUpdate(stSql)
Gruß
Robert
https://de.libreoffice.org/get-help/documentation/
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=base_handbuch
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=xml_formulare
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=base_handbuch
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=xml_formulare
-
- Beiträge: 4
- Registriert: Sa 27. Jul 2019, 15:09
Re: Daten mit Basic aus Tabelle auslesen und schreiben
Danke RobertG,
ja das klappt.
Und wie bekomme ich die Feldinhalte in Basic-Variablen ?
Gruß Loeckenhoff
ja das klappt.
Und wie bekomme ich die Feldinhalte in Basic-Variablen ?
Gruß Loeckenhoff
Re: Daten mit Basic aus Tabelle auslesen und schreiben
Code: Alles auswählen
' wichtig, falls Du mal von hinten nach vorne durch das Resultset isterieren moechtest:
SQL_Anweisung = com.sun.star.sdbc.ResultSetType.SCROLL_INSENSITIVE
select case LCase(left(stSql,6))
case "select"
' HOLT die Daten
oResultset=SQL_Anweisung.executeQuery(stSql)
' scrollt durch das Ergebnis (Spalte 1 in diesem Fall) bis zum Ende ...
while oResultset.next
VariableX=oResultset.getstring(1)
msgbox "Zeile " & oResultset.row & " = " & VariableX
wend
case else
' FUEHRT ein Daten-veraenderndes Statement AUS
SQL_Anweisung.executeUpdate(stSql)
end select
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: Daten mit Basic aus Tabelle auslesen und schreiben
Hallo Loeckenhoff,
meinst Du mit den Feldinhalten die Inhalte, die gerade in Deinem Formular angezeigt werden?
Ansonsten reicht es doch, das Formular anschließend zu aktualisieren.
Schau Dir gegebenenfalls einfach einmal das Makro-Kapitel des Handbuches an.
Gruß
Robert
meinst Du mit den Feldinhalten die Inhalte, die gerade in Deinem Formular angezeigt werden?
Ansonsten reicht es doch, das Formular anschließend zu aktualisieren.
Schau Dir gegebenenfalls einfach einmal das Makro-Kapitel des Handbuches an.
Gruß
Robert
https://de.libreoffice.org/get-help/documentation/
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=base_handbuch
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=xml_formulare
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=base_handbuch
https://www.familiegrosskopf.de/robert/index.php?&Inhalt=xml_formulare
-
- Beiträge: 4
- Registriert: Sa 27. Jul 2019, 15:09
Re: Daten mit Basic aus Tabelle auslesen und schreiben
Danke gogo und RobertG,
ich sehe, dass ich noch viel üben muss, um Makros in Base zu verstehen.
Für weitere Anregungen bin ich dankbar. Doch jetzt muss ich alles erst verarbeiten.
Ich schau mir auch das Kapitel Makros im Handbuch an.
Bis dann Gruß Loeckenhoff
ich sehe, dass ich noch viel üben muss, um Makros in Base zu verstehen.
Für weitere Anregungen bin ich dankbar. Doch jetzt muss ich alles erst verarbeiten.
Ich schau mir auch das Kapitel Makros im Handbuch an.
Bis dann Gruß Loeckenhoff
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.