![]() |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Hallo Ihr lieben,
sooo aktueller Stand:-D Delphi Deinstalliert und alles wieder neu Installiert:thumb: sowie Tdbf 6.9.1 und siehe da... es läuft, es lässt sich alles verändern und wird sogar in der Kunden.dbf gespeichert:thumb: Jetzt muss ich mich nur noch mit dem Filter auseinander setzten...:shock: Von Kunde bis Kunde auswählen, und Betrag einsetzen. Vorest Danke an alle für eure mühe, tolle Gemeinschaft:thumb::thumb: |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo allerseits
wollte nicht nochmals ein neues Thema eröffnen und fahre hier mit meiner frage fort...: Das mit dem Filtern klappt leider nicht so ganz. Was habe ich schon gemacht: Habe auf der Form eine TQuery komponente gesetzt und im Inspektor Datasource Datasource1 ausgewählt. Doppelklick auf den Button in der Form und folgender sql code eingegeben:
Code:
leider erscheint nach F9 folgende meldung:
procedure TMainForm.Button2Click(Sender: TObject);
begin query1.sql.text:='select * from Kunden limit '+IntToStr(vonGast.Text)+', '+IntToStr(bisGast.Text); end; was ist mit überladener Version gemeint? Kurz vor dem Ziel so etwas...:roll: :evil: |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Zitat:
Entweder:
Delphi-Quellcode:
oder
procedure TMainForm.Button2Click(Sender: TObject);
begin query1.sql.text := 'select * from Kunden limit ' + vonGast.Text + ', ' + bisGast.Text; end;
Delphi-Quellcode:
wobei mir das entstehende SQL-Statement seltsam vorkommt:
procedure TMainForm.Button2Click(Sender: TObject);
begin query1.sql.text:= Format('select * from Kunden limit %s, %s',[vonGast.Text,bisGast.Text]); end;
SQL-Code:
also z. B.:
select * from Kunden limit vonGast, bisGast
SQL-Code:
select * from Kunden limit 10, 20
Hätte hier eher sowas erwartet:
SQL-Code:
also z. B.:
select * from Kunden where kunr between vonGast and bisGast
SQL-Code:
select * from Kunden where kunr between 10 and 20
|
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Könnte es sein, daß
Delphi-Quellcode:
u.U. kein Integer ist?
vonGast.Text
Gruß K-H |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Liste der Anhänge anzeigen (Anzahl: 1)
@nahpets
habe deinen code so übernommen und eingestzt, jetzt kommt zwar keine Fehlermeldung mehr aber es passiert auch nichts...:shock: also vonGast.text und bisGast.text waren die Edit1.text und Edit2.text die umbenannt habe. Zum verständniss: Ich habe eine Dbgrid wo die kunden.dbf eingelesen wird, im Feld KUNR (Gast Nr.) habe ich z.B. 10 Kunden drin, beim einlesen der Tabelle werden alle 10 Kunden angezeigt. Jetzt möchte ich gerne einen Filter setzen, also zeige mir von Gast 1 bis Gast 5 an. Dachte dass es mit einer sql abfrage möglich sein sollte... |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Was benutzt Du jetzt eigentlich in Deinem Programm?
TDBF oder TQuery? TQuery benötigt die BDE. mit
Delphi-Quellcode:
wird der Query ein Statement zugewiesen, mehr aber auch nicht.
query1.sql.text := Format('select * from Kunden where kunr between %s and %s',[vonGast.Text,bisGast.Text]);
Wenn Du möchtstes, dass es auch ausgeführt wird, solltest Du die Abfrage öffnen.
Delphi-Quellcode:
query1.Close;
query1.sql.text:= Format('select * from Kunden where kunr between %s and %s',[vonGast.Text,bisGast.Text]); query1.Open; |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Ich benutze die TDBF
brauche ich eigentlich die TQuery komponente? obwohl diese mit Datasource1 verbunden ist, kann ich Active nicht auf True setzten, da kommt: Query1: keine SQL Anweisung verfügbar [Edit] jaaa lesen klar, TQuery benötigt die BDE.. also brauche ich die Tquery komponente gar nicht.[/Edit] Sorry wenn ich evtl. nicht richtig ausdrucke, bin noch in der "lernphase" mit Delphi Habe auch diesen code von Dir benutzt, mit der Anweisung zu öffnen... hmm leider "bewegt" also wird nichts gefiltert, es bleibt alles so wie es ist... |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Entweder TDBF oder TQuery (BDE).
Gemischt geht nicht. TDBF kann kein SQL. Filter mit TDBF funktionieren. Wie sieht Dein (weiter oben angedeuteter) Versuch, mit Filter zu arbeiten, aus? (Quelltext? - Dann könnte man eventuell Hilfestellung geben, damit eine grundsätzlich gegebene Funktionalität auch von Dir umgesetzt werden kann.) Wie Du die Abfrage öffnest, steht in meinem letzten Post! Query.Active = True funktioniert nur, wenn Du vorher ein SQL-Statement zugewiesen hast. Grundsätzlich: Wenn Du eine Frage hast, die auf eine "Fehlfunktion" des Quelltextes hindeuten könnte, dann poste bitte jedesmal den dann aktuellen Quelltext. Wie soll man ohne diesen denn jetzt feststellen, warum bei Dir der übernommenen Quelltext nicht funktioniert? Hier ist gerade sehr diesiges, verregnetes Wetter, deshalb reicht meine :glaskugel: nicht aus, um die eventuell vorhandenen Probleme auf unbekannte Entfernung erkennen zu können ;-) |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Natürlich, Du hast recht:thumb: mache gleich ein Copy/Paste...:-D
Sooo is drin, ein wenig lang...:shock: Hoffe Du findest etwas:-D
Delphi-Quellcode:
unit Main;
interface uses SysUtils, Windows, Messages, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, Buttons, ExtCtrls, Menus, ComCtrls, DB, Grids, DBGrids, dbf, DBTables, XPMan, jpeg, ToolWin, RpRender, RpRenderPDF, RpDefine, RpRave, RpCon, RpConDS, ImgList, FMTBcd, SqlExpr; type TMainForm = class(TForm) MainMenu: TMainMenu; FileExitItem: TMenuItem; EditUndoItem: TMenuItem; EditCutItem: TMenuItem; EditCopyItem: TMenuItem; EditPasteItem: TMenuItem; DataSource1: TDataSource; DBGrid1: TDBGrid; Edit3: TEdit; Button1: TButton; Dbf1: TDbf; XPManifest1: TXPManifest; Edit4: TEdit; Button4: TButton; GroupBox1: TGroupBox; Label3: TLabel; Label4: TLabel; vonGast: TEdit; bisGast: TEdit; Button2: TButton; GroupBox2: TGroupBox; Label5: TLabel; Label6: TLabel; Timer1: TTimer; StatusBar1: TStatusBar; OpenDialog1: TOpenDialog; Oeffnen1: TMenuItem; RvRenderPDF1: TRvRenderPDF; RvDataSetConnection1: TRvDataSetConnection; RvCustomConnection1: TRvCustomConnection; RvProject1: TRvProject; Drucken1: TMenuItem; PrintDialog1: TPrintDialog; Dbf1KUNR: TIntegerField; Dbf1KUNAM: TStringField; Dbf1KUANRED: TStringField; Dbf1KUFIRMA: TStringField; Dbf1KUSALDO: TFloatField; Dbf1KULIMIT: TLargeintField; ImageList1: TImageList; Query1: TQuery; procedure FormCreate(Sender: TObject); procedure FileExit(Sender: TObject); procedure EditUndo(Sender: TObject); procedure EditCut(Sender: TObject); procedure EditCopy(Sender: TObject); procedure EditPaste(Sender: TObject); procedure Button1Click(Sender: TObject); procedure Button4Click(Sender: TObject); procedure Timer1Timer(Sender: TObject); procedure Oeffnen1Click(Sender: TObject); procedure Drucken1Click(Sender: TObject); procedure Edit3KeyPress(Sender: TObject; var Key: Char); procedure vonGastChange(Sender: TObject); procedure Edit3Change(Sender: TObject); procedure Button2Click(Sender: TObject); end; var MainForm: TMainForm; implementation {$r *.dfm} procedure TMainForm.FormCreate(Sender: TObject); begin Statusbar1.Panels[1].Text:=TimeToStr (now); Statusbar1.Panels[2].Text:=DateToStr (now); end; procedure TMainForm.FileExit(Sender: TObject); begin dbf1.active := false; dbf1.Close; application.Terminate; end; procedure TMainForm.EditUndo(Sender: TObject); begin { Code zur Durchführung von Bearbeiten Rückgängig hinzufügen } end; procedure TMainForm.EditCut(Sender: TObject); begin { Code zur Durchführung von Bearbeiten Ausschneiden hinzufügen } end; procedure TMainForm.EditCopy(Sender: TObject); begin { Code zur Durchführung von Bearbeiten Kopieren hinzufügen } end; procedure TMainForm.EditPaste(Sender: TObject); begin { Code zur Durchführung von Bearbeiten Einfügen hinzufügen } end; procedure TMainForm.Button1Click(Sender: TObject); begin dbf1.First; while not dbf1.EoF do begin dbf1.Edit; dbf1.FieldByName('KULimit').AsString := edit3.Text; dbf1.Post; dbf1.Next; end; end; procedure TMainForm.Button4Click(Sender: TObject); begin dbf1.First; while not dbf1.EoF do begin dbf1.Edit; dbf1.FieldByName('KULimit').AsString := edit4.Text; dbf1.Post; dbf1.Next; end; end; procedure TMainForm.Timer1Timer(Sender: TObject); begin Statusbar1.Panels[1].Text:=DateToStr (now); Statusbar1.Panels[2].Text:=TimeToStr (now); end; procedure TMainForm.Oeffnen1Click(Sender: TObject); begin dbf1.active := false; DataSource1.DataSet := dbf1; OpenDialog1.execute; dbf1.active := true; end; procedure TMainForm.Drucken1Click(Sender: TObject); begin RvProject1.Open; RvProject1.Execute; end; procedure TMainForm.Edit3KeyPress(Sender: TObject; var Key: Char); begin if NOT (Key in [#08, '0'..'9']) then Key := #0; end; procedure TMainForm.vonGastChange(Sender: TObject); //Filter Button wird eingeschaltet begin button2.Enabled:=true; end; procedure TMainForm.Edit3Change(Sender: TObject); //OK Button wird eingeschaltet begin button1.Enabled:=true; end; procedure TMainForm.Button2Click(Sender: TObject); begin query1.Close; query1.sql.text := 'select * from Kunden limit ' + vonGast.Text + ', ' + bisGast.Text; query1.Open; end; end. |
AW: Problem mit zugriff auf dbf Dateien und bearbeiten.
Zitat:
Delphi-Quellcode:
schließt die Tabelle, das folgende Close ist dann überflüssig.
Active := false;
Das Programm beenden geht auch eleganter durch das Schließen des Formulares.
Delphi-Quellcode:
Gibt den Buttons bitte Namen, an denen man erkennen kann, welche Funktion sie ausüben sollen (z. B. statt Button1 btnKuLimitSetzen).
procedure TMainForm.FileExit(Sender: TObject);
begin dbf1.Close; Close; end; Den Editfeldern gib bitte Namen, die auf ihren Inhalt schließen lassen (z. B. statt edit1 edKuLimit). Und wenn Du dann noch jeder Prozedur einen Kommentar verpasst, was ihre Aufgabe sein soll, so könnte das durchaus hilfreich sein. Man kann dann ggfls. aus Vergleich von Kommentar und Quelltext auf eventuelle Probleme schließen bzw. Widersprüche zwischen "Theorie und Praxis" erkennen. Und wenn man ein Programm nach Jahren nochmal pflegen muss, dann reicht es den Kommentar zu lesen und nicht erst mehr oder weniger Quelltext, aus dem man dann auf die (vermutete) Aufgabe schließen muss. Was soll denn hier jetzt passieren? Für alle Datensätze KULimit auf einen einheitlichen Wert setzen?
Delphi-Quellcode:
oder war das der Versuch für die gefilterten Sätze KULimit zu setzen?
procedure TMainForm.Button1Click(Sender: TObject);
begin dbf1.First; while not dbf1.EoF do begin dbf1.Edit; dbf1.FieldByName('KULimit').AsString := edit3.Text; dbf1.Post; dbf1.Next; end; end; Dann könnte eventuell dashier hilfreich sein:
Delphi-Quellcode:
Dashier würd' ich auch anpassen (wenn ich denn den Sinn verstehen würde).
procedure TMainForm.btnKULimitClick(Sender: TObject);
// Für alle Datensätze mit KUNR im Bereich vonGast - bisGast // KULimit auf den Wert aus edKULimit setzen. begin dbf1.Filtered := false; dbf1.Filter := Format('KUNR >= %s and KUNR <= %s', [vonGast.Text, bisGast.Text]); dbf1.Filtered := true; dbf1.First; while not dbf1.EoF do begin dbf1.Edit; dbf1.FieldByName('KULimit').AsString := edKULimit.Text; dbf1.Post; dbf1.Next; end; dbf1.Filtered := false; dbf1.Filter := ''; dbf1.First; end; Unklar ist z. B., was hier denn geöffnet werden soll, das Ergebnis des OpenDialogs wird doch überhauptnicht ausgewertet.
Delphi-Quellcode:
Die bisherige Funktion entspricht:
procedure TMainForm.Oeffnen1Click(Sender: TObject);
begin dbf1.active := false; DataSource1.DataSet := dbf1; OpenDialog1.execute; dbf1.active := true; end;
Delphi-Quellcode:
Soll hier eventuell eine Datei ausgewählt werden?
procedure TMainForm.Oeffnen1Click(Sender: TObject);
begin dbf1.Close; dbf1.Open; end; Dann könnte dashier eventuell eine Lösung sein:
Delphi-Quellcode:
procedure TMainForm.Oeffnen1Click(Sender: TObject);
begin dbf1.Close if OpenDialog1.Execute then begin dbf1.TableName := OpenDialog1.FileName; end; dbf1.Open; end; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:55 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz