AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi clientdataset datenmenge weder im editier noch im einfügemodus
Thema durchsuchen
Ansicht
Themen-Optionen

clientdataset datenmenge weder im editier noch im einfügemodus

Ein Thema von Kevin11 · begonnen am 15. Nov 2011 · letzter Beitrag vom 15. Nov 2011
Antwort Antwort
Kevin11

Registriert seit: 11. Aug 2011
113 Beiträge
 
Delphi XE Professional
 
#1

clientdataset datenmenge weder im editier noch im einfügemodus

  Alt 15. Nov 2011, 15:20
Datenbank: Firebird • Version: 2 • Zugriff über: dbX
Hallo,

ich bekomme den Fehler, der im Titel steht in folgender Funktion:

Delphi-Quellcode:
function AddPELehrg(_Bereich: string;_ID: Integer; _Nr, _Name, _Lehrgang, _Von, _Bis, _Ort: String; _Best :integer): Boolean;
var
  VZqLehrgänge : TClientDataSet;
  VZqTemp : TADOQuery;
begin
Result := True;

  Form2.Memo1.Lines.Add(#9#9#9+'Lehrgänge');


  Result := False;

  VZqLehrgänge := Form2.ClientDataSet1;
  with VZqLehrgänge do
  begin
    Close;
// Connection := FFBConnection;
    CommandText := 'SELECT * FROM '+_Bereich+'_LEHRG';
    Open;

    if not Active then
      Active := True;

    if (State <> dsEdit) or (State <> dsInsert) then
    begin
      Edit;
    end
    else
    begin
      Insert;
    end;
          FieldByName(_Bereich+'_ID').Value := GetMaxID(_Bereich+'_LEHRG', Form2.SQLConnection);

          FieldByName(_Bereich+'_INDEX').Value := _ID;
          FieldByName(_Bereich+'_NR').Value := GetString(_Nr, 15);
          FieldByName(_Bereich+'_NAME').Value := GetString(_Name, 30);

          FieldByName(_Bereich+'_LEHRG_LANG').Value := _Lehrgang;

          try
// if _Von <> '' then
            if Length(_Von) = 10 then
            begin
              FieldByName(_Bereich+'_ZEITRAUM_VD').AsString := _Von;
            end;
          except
          end;
          try
            if Length(_Bis) = 10 then
              FieldByName(_Bereich+'_ZEITRAUM_BD').AsString := _Bis;
          except
          end;

          FieldByName(_Bereich+'_LEHRG_ORT').Value := _Ort;


          FieldByName(_Bereich+'_LEHRG_OK').Value := _Best;

        ApplyUpdates(0);
        Post;

    Close;
  end;
  Result := True;

  FreeAndNil(VZqTemp);
  FreeAndNil(VZqLehrgänge);
end;
Ich find keinen Fehler.
"Wer mit künstlicher Intelligenz arbeitet, muß auch mit natürlicher Dummheit rechnen." (Klaus Kornwachs)
  Mit Zitat antworten Zitat
Benutzerbild von ergeka
ergeka

Registriert seit: 5. Mär 2010
Ort: Karlsruhe
33 Beiträge
 
Delphi 12 Athens
 
#2

AW: clientdataset datenmenge weder im editier noch im einfügemodus

  Alt 15. Nov 2011, 15:34
Müsste das 'ApplyUpdates' nicht nach dem 'Post' stehen ?

Ralf
  Mit Zitat antworten Zitat
FrankJ28

Registriert seit: 7. Apr 2008
211 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: clientdataset datenmenge weder im editier noch im einfügemodus

  Alt 15. Nov 2011, 15:39
Hallo Kevin,
mir ist dein Code nicht so ganz klar:

1. Dataset wird geschlossen (close)
2. neues SQL und dann öffnen (open)
3. Active??? nach dem open ist das DS active
4. edit/insert. Soll etwas neu eingefügt oder der erste Satz überschrieben werden?
5. Felder füllen ...
6. Post zum Speichern. Aber nochmals überlegen, ob der erste Satz überschrieben (Edit) oder ein neuer eingefügt (insert) werden soll. Da du dir eine MaxId holst, tippe ich einmal auf neuen Satz

Frage: warum immer result true?

Ciao
Frank
"Sage was du tust, und tue was du sagst"
Johannes Rau
  Mit Zitat antworten Zitat
Kevin11

Registriert seit: 11. Aug 2011
113 Beiträge
 
Delphi XE Professional
 
#4

AW: clientdataset datenmenge weder im editier noch im einfügemodus

  Alt 15. Nov 2011, 15:41
Doch natürlich. Immer diese Leichtsinnsfehler. :/

Vielen Dank, jetzt geht es.
"Wer mit künstlicher Intelligenz arbeitet, muß auch mit natürlicher Dummheit rechnen." (Klaus Kornwachs)
  Mit Zitat antworten Zitat
Kevin11

Registriert seit: 11. Aug 2011
113 Beiträge
 
Delphi XE Professional
 
#5

AW: clientdataset datenmenge weder im editier noch im einfügemodus

  Alt 15. Nov 2011, 15:44
Hallo Kevin,
mir ist dein Code nicht so ganz klar:

1. Dataset wird geschlossen (close)
2. neues SQL und dann öffnen (open)
3. Active??? nach dem open ist das DS active
4. edit/insert. Soll etwas neu eingefügt oder der erste Satz überschrieben werden?
5. Felder füllen ...
6. Post zum Speichern. Aber nochmals überlegen, ob der erste Satz überschrieben (Edit) oder ein neuer eingefügt (insert) werden soll. Da du dir eine MaxId holst, tippe ich einmal auf neuen Satz

Frage: warum immer result true?

Ciao
Frank
Hi Frank,

ich prüf immer ob die Funktion auch wirrklich ausgeführt wurde. Das mit dem Edit hatte ich nur testweiße in meiner Funktion, ich habe es aber schon wieder entfernt.
"Wer mit künstlicher Intelligenz arbeitet, muß auch mit natürlicher Dummheit rechnen." (Klaus Kornwachs)
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#6

AW: clientdataset datenmenge weder im editier noch im einfügemodus

  Alt 15. Nov 2011, 16:56
Ich sehe da noch einige Fehler in dem Code.
Delphi-Quellcode:
...
    Close;
// Connection := FFBConnection;
    CommandText := 'SELECT * FROM '+_Bereich+'_LEHRG';
    Open;


    // überflüssiger Code, da durch "Open" die Datenmenge automatisch auf aktiv gesetzt wird
    // *********
    if not Active then
      Active := True;
    // *********

Nachdem der Tabellenname schon vom Bereich abhängt, ist es eine ganze schlechte Idee auch noch die Feldnamen vom Bereich abhängig zu machen:
Delphi-Quellcode:
...
    CommandText := 'SELECT * FROM '+_Bereich+'_LEHRG';
    Open;
...
    // Feldnamen sollten für alle Tabellen gleich sein!
    FieldByName(_Bereich+'_ID').Value := GetMaxID(_Bereich+'_LEHRG', Form2.SQLConnection);
    FieldByName(_Bereich+'_INDEX').Value := _ID;

Man sollte auch nicht Komponenten auf einem Formular mit FreeAndNil() freigeben:
Delphi-Quellcode:
...
  VZqLehrgänge := Form2.ClientDataSet1;
...
  // nicht gut - beim nächsten Mal ist das ClientDataSet weg und dann gibt es eine Zugriffsverletzung
  FreeAndNil(VZqTemp);
  FreeAndNil(VZqLehrgänge);
Andreas
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:28 Uhr.
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