... woher weiß ich und vor allem ADODataSet in welcher Tabelle der neue Datensatz gespeichert werden soll?
Ist im Grunde alles ziemlich einfach: Du hast erst einmal eine AdoConnection, die du entsprechend einrichtest, damit die richtige Datenbank angesprochen wird. Dann nimmst du dir ein Dataset dazu und weist dessen
Connection-Property deine AdoConnection zu. Um nun die richtige Tabelle auszuwählen, klickst du auf die drei Punkte im Property
CommandText. Es erscheint ein selbsterklärendes Dialogfenster, in dessen oberer Combobox du die Tabelle auswählst und in der unteren Combobox die anzuzeigenden Felder. Deine Auswahl wird automatisch zu einem
SQL-String zusammengebaut. Es wird nun immer die eingetragene Tabelle angesprochen.
Erzeugst du ein Dataset zur Laufzeit, um z.B. neue Datensätze anzulegen, gehst du analog vor:
Delphi-Quellcode:
function TDatMod.Waren_NeuerDatensatz(Art_Nr, Anzahl, Lieferant: Integer; Farbe : String): Boolean;
Var
AsetNeu : TAdoDataset;
begin
Result := False;
AsetNeu := TAdoDataset.Create(DatMod);
Try
AsetNeu.Connection := ADOCon;
AsetNeu.CommandText := 'select * from WarenTabelle';
AsetNeu.Active := True;
AsetNeu.Append; // oder AsetNeu.Insert;
AsetNeu.FieldByName('ArtikelNr').AsInteger := Art_Nr;
AsetNeu.FieldByName('Anzahl').AsInteger := Anzahl;
AsetNeu.FieldByName('Lieferant').AsInteger := Lieferant;
AsetNeu.FieldByName('Farbe').AsString := Farbe;
AsetNeu.Post;
Result := True;
Finally
FreeAndNil(AsetNeu);
End;
end;
Oder wenn du mit einem
Query und
SQL arbeiten willst:
Delphi-Quellcode:
function TDatMod.Waren_NeuerDatensatz(Art_Nr, Anzahl, Lieferant: Integer; Farbe : String): Boolean;
Const
K = ','; // Komma
Ka = '('; // KlammerAuf
Kz = ')'; // KlammerZu
Var
AQuery : TAdoQuery;
begin
Result := False;
AQuery := TAdoDataset.Create(DatMod);
Try
AQuery.Connection := ADOCon;
AQuery.SQL.Append('insert into WarenTabelle');
AQuery.SQL.Append(Ka + 'ArtikelNr, Anzahl, Lieferant, Farbe' + Kz);
AQuery.SQL.Append('values');
AQuery.SQL.Append(Ka + IntTostr(Art_Nr) + K + IntToStr(Anzahl) + K + IntToStr(Lieferant) + K + QuotedStr(Farbe) + Kz);
AQuery.ExecSQL;
Result := True;
Finally
FreeAndNil(AsetNeu);
End;
end;
Du siehst hier am Aufbau der beiden Funktionen im Grunde alles, was dazu nötig ist, neue Datensätze einzufügen.