Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   gesonderte Ergebnisberechnung in DB-Tab eingeben (https://www.delphipraxis.net/192351-gesonderte-ergebnisberechnung-db-tab-eingeben.html)

EdAdvokat 11. Apr 2017 10:40

Datenbank: SQLite-3 • Version: 3 • Zugriff über: dbExpress

gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo zusammen, meine sehr bescheidenen Kenntnisse in Fragen Datenbanken stehen meinem Bestreben hier etwas Brauchbares zu erreichen noch im Wege.
Mit Hilfe einiger Mitglieder des DP-Forums, vor allem die von Haentschman entstand das beigefügte kleine Übungsprogramm mit einer SQLite-Datenbank.
Das Aufrufen einer bestehenden Datenbanktabelle funktioniert soweit ganz gut. Nun möchte ich jedoch als Pilotlösung (also als Schlüssel, wie man das machen könnte) erreichen, dass unabhängig von der Datenbank eine Berechnung (beispielsweise a+b oder eine Rabattberechnung usw.) durchgeführt wird und dieses Ergebnis dann in die bestehende Datenbank aufgenommen wird. Nun dachte ich mir, einfach ein TEdit in das bestehende Programmformular aufzunehmen, um dort das Berechnungsergebnis zu simulieren, dass dann beispielsweise in das Datenbankfeld "Anzahl" eines oder ggf. auch mehrerer Datensätze eingefügt wird.
Dazu habe ich ein OnClick-Routine geschrieben, in der Erwartung, dass meine simulierte Ergebniseingabe im Feld "Anzahl" erscheint, doch es passiert überhaupt nichts... gar nichts.

Delphi-Quellcode:
procedure TMainFrm.btnTest_inputClick(Sender: TObject);
var
  CurrentCustomerID: string;
begin
  qryMain.SQL.Clear;
  qryMain.Params.Clear;
   if IsEdit then
begin
  CurrentCustomerID := lvProductList.Selected.Caption;
  qryMain.SQL.Text := 'UPDATE WARENVERKAUF SET KDNR=:KDNR,NAME=:NAME,VORNAME=:VORNAME,FIRMA=:FIRMA,PRODUKT=:PRODUKT,ANZAHL=:ANZAHL,PREIS=:PREIS,MEMO=:MEMO WHERE ID = :CID';
  qryMain.ParamByName('CID').AsString := CurrentCustomerID;
  qryMain.ParamByName('Anzahl').Text:=(edtTest_input.text);
  qryMain.ExecSQL;
  RefreshItems(CurrentCustomerID, edtCustomerNumber.Text, Name.Text, vorname.Text, firma.Text, produkt.Text, Anzahl.Text, Preis.Text);end; end;
Ist mein Denkansatz überhaupt tragbar oder muss ich ggf. ganz anders herangehen ggf. eine neue Tabelle entwerfen mit einem gesonderten leeren Feld, dass dann bestückt wird?
Es muss doch möglich sein, beispielsweise mit einem Datenbankfeld "Preis" daraus den Netto- und Bruttopreis und auch die MWST zu berechnen und dann wieder in ein gesondertes Datenbankfeld einzugeben.
Das Ganze dient nur für mein Verständnis.
Für Tipps, wie ich hier weiterkomme wäre ich sehr dankbar.
Norbert

p80286 11. Apr 2017 10:56

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Was verbirgt sich hinter "RefreshItems"?
Da ich überzeiugter Ignorant von Datensensitiven Controls bin (DBGrid etc.) würde ich das ganze ungefähr so lösen:
(pseudocode)
Delphi-Quellcode:
Mywerte.preis:=sqlGetpreis;
Mywerte.anzahl:=sqlGetAnzahl;
Mywerte.Summe:=Berechne(MyWerte.Preis,MyWerte.Anzahl);
sqlUpdateDB(Mywerte.Summe);
Display(sqlGetSumme);
Also grundsätzlich einen neuen Wert in die DB schreiben und diesen dann sofort wieder abfragen.

Gruß
K-H

haentschman 11. Apr 2017 12:30

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Moin...:P
Du hast die Fehlermeldung vergessen. 8-)

Delphi-Quellcode:
qryMain.ParamByName('Anzahl').AsString := edtTestInput.Text;
...
ParamByName erwartet As... Das Datenfeld As... muß auch den gleichen Datentyp haben.

PS: Bitte verzichte auf _ in den Namen. :P In Delphi ist CamelCase üblich...deshalb wird das auch PascalCase genannt. https://de.wikipedia.org/wiki/Camelcase siehe Programmiersprachen.

Delphi-Quellcode:
RefreshItems(CurrentCustomerID, edtCustomerNumber.Text, Name.Text, vorname.Text, firma.Text, produkt.Text, Anzahl.Text, Preis.Text);
...
...da wird nur das Listview gefüllt/aktualisiert.

@p80286:
EdAdvokat macht seine ersten Schritte mit Datenbank... Wie kriege ich welche Werte in die Datenbank, wie kriege ich sie wieder raus. :wink: Das ganze in Prozeduren zu verlagern kommt später...:thumb:

Zum Problem:
Zitat:

dass meine simulierte Ergebniseingabe im Feld "Anzahl" erscheint, doch es passiert überhaupt nichts... gar nichts.
...wo erwartest du was? Im Feld in der DB?

EdAdvokat 11. Apr 2017 12:50

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Danke, das war ein Flüchtigkeitsfehler naürlich muss es ...asInteger heißen.
Fehlermeldung: keine! Er läuft durch wie ein heißes Messer durch die Butter, doch keine Butter da. Also nach Eingabe von beliegigen Zahlen in des Editfeld und buttonClick (jetzt ohne Unterstrich) passiert nichts.

Delphi-Quellcode:
 qryMain.ParamByName('Anzahl').asInteger:=strtoint(edtTestInput.text);
In der Liste ändert sich die Anzahl überhaupt nicht auch nach Neuaufruf der Tabelle nur die bekannten Inhalte. Er nimmt also die Eingabe nicht an.
Norbert

haentschman 11. Apr 2017 12:55

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Hallöle...:P
Hast du mal mit einem Datenbankeditor in die Datenbank geschaut ob wirklich nichts in der Datenbank steht?

OK...machen wir einen Schritt zurück. :wink:
1. Du legst ein neues Projekt an mit deinen Controls auf der Form.
Dann machen wir jeden Schritt gemeinsam und dann stellst du das hier rein...und wir begutachten das. :zwinker:
...dann nächster Schritt. (evt. Copy/Paste)

2. Du brauchst eine Datenbankverbindung (eigene procedure in private), dann im OnCreate aufrufen, im OnDestroy die Connection schließen.
...wenn du fertig bist hier einstellen. :thumb:

EdAdvokat 11. Apr 2017 13:15

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Habe mit dem SQLite-Manager in Firebird die Datenbanktabelle aufgerufen und auch dort haben Lehmann und Anton immer noch 50 Sück im Bestand, doch ich habe stets 666 eingegeben. Dann habe ich das Programm außerhalb der laufenden IDE gestartet - nichts. Dann nach Eingabe meines Wertes 666 geprüft, ob sich am Zeitstempel der Datenbank was verändert - nichts, jedoch wenn ich auf übernehmen klicke ändert sich der Zeitstempel, jedoch ohne meine gewünschten 666 im Feld Anzahl. Leider.

sko1 11. Apr 2017 13:47

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Probier mal folgende Schritte:

Abfrage eines Datensatzes
Query.sql.text := 'Select irgendwas...';
Öffnen
Query.Open;
Datenzeiger positionieren
Query.first;
Editmode einschalten
Query.edit;
Feld ändern
Query.fieldByName('feldname').asinteger := ....
Zurückschreiben
Query.Post;

Ciao
Stefan

p80286 11. Apr 2017 14:03

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
@Haentschman
da
Delphi-Quellcode:
   qryMain.SQL.Text := 'UPDATE WARENVERKAUF SET KDNR=:KDNR,NAME=:NAME,VORNAME=:VORNAME,FIRMA=:FIRMA,PRODUKT=:PRODUKT,ANZAHL=:ANZAHL,PREIS=:PREIS,MEMO=:MEMO WHERE ID = :CID';
   qryMain.ParamByName('CID').AsString := CurrentCustomerID;
   qryMain.ParamByName('Anzahl').Text:=(edtTest_input.text);
   qryMain.ExecSQL;
denke ich er ist auf dem richtigen Weg. Ob die Syntax so ganz richtig ist(?) Bei mir werden die Parameter immer mit
Delphi-Quellcode:
.Value:=
übergenen.
Was mich jetzt wundert, ist daß es keine Fehlermeldung gibt (Butter??) denn auf den ersten Blick ist das ganz in Ordnung. Was sein könnte, daß die DB sich an den NULL-Feldern (z.B. MEMO) verschluckt, weil keine Daten kommen. Ggf. muß das Update auf die relevanten Felder gekürzt werden.
oder muß vllt. ein explizites "EndofTransaction" mit gegeben werden? oder ein "Commit"?

Gruß
K-H

EdAdvokat 11. Apr 2017 14:19

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Liste der Anhänge anzeigen (Anzahl: 1)
Danke für die Mühe mit mir. Hoffentlich ist das richtig. Habe jedoch das ListView und die TEdits drin gelassen. Connect in ges. priv. Procedure und in OnCreate aufgerufen.
ConMain auf Inhalte geprüft. Datenbanktabelle wie gehabt. Verbindung besteht.

haentschman 11. Apr 2017 14:21

AW: gesonderte Ergebnisberechnung in DB-Tab eingeben
 
Hallöle...:P
Zitat:

Abfrage eines Datensatzes
Query.sql.text := 'Select irgendwas...';
Öffnen
Query.Open;
Datenzeiger positionieren
Query.first;
Editmode einschalten
Query.edit;
Feld ändern
Query.fieldByName('feldname').asinteger := ....
Zurückschreiben
Query.Post;
..bitte keine DB sensitiven Controls. Späterhinaus will er seine Daten in Objektlisten speichern... :thumb:
Zitat:

denke ich er ist auf dem richtigen Weg. Ob die Syntax so ganz richtig ist(?) Bei mir werden die Parameter immer mit .Value:= übergenen.
...Value ist auch eine Möglichkeit. Aber intern hat er immer den Cast zu richtigem Typ. :zwinker: As...spricht gleich den richtigen Typ der in der DB an. So findet auch heraus das man einen falschen Typ übergeben hat. :thumb:

Zum Problem am Beispiel:
Delphi-Quellcode:
qryMain.SQL.Text := 'UPDATE WARENVERKAUF SET KDNR=:KDNR,NAME=:NAME,VORNAME=:VORNAME,FIRMA=:FIRMA,PRODUKT=:PRODUKT,ANZAHL=:ANZAHL,PREIS=:PREIS,MEMO=:MEMO WHERE ID = :CID';
qryMain.ParamByName('CID').AsString := CurrentCustomerID; // Ist die ID auch bekannt? Was sagt der Debugger über den Wert?
qryMain.ParamByName('Anzahl').AsInteger:= edtTestInput.Text;
qryMain.ExecSQL;
... Was steht im Feld ID der Datenbank drin? LEHMANN = ID(?) Du kannst nicht einfach den Wert eintragen. Du mußt auch der Datenbank sagen zu welchem Kunden (CurrentCustomerID) der Wert gehört.
Mache ein Edit nebendran mit der ID des Datensatzes. Diese "ausgewählte" ID übergibst du dem UPDATE Statement anstatt der CurrentCustomerID. Nach dem Eintragen in die DB mußt du auch die Daten wieder abholen (SELECT) und die LV aktualisieren.


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:53 Uhr.
Seite 1 von 3  1 23      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz