AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Kann StrinGrid nicht in der DB speichern
Thema durchsuchen
Ansicht
Themen-Optionen

Kann StrinGrid nicht in der DB speichern

Ein Thema von Ati · begonnen am 18. Jul 2006 · letzter Beitrag vom 19. Jul 2006
 
Ati

Registriert seit: 16. Okt 2003
Ort: Gelsenkirchen
406 Beiträge
 
Delphi 3 Professional
 
#1

Kann StrinGrid nicht in der DB speichern

  Alt 18. Jul 2006, 17:24
Datenbank: Firebird • Version: 1.5 • Zugriff über: Zeos
Hallo zusammen,

nachdem ich es jetzt geschaft habe eine CSV-Datei in einem StringGrid darzustellen (hier mal der Code)
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
Var f: TextFile;
    Zeile, I: Integer;
    ZeileS: String;
    ZeileA: TStringDynArray;

  Begin
    OpenDialog1.Execute;
    Zeile := 0;
    //StringGrid1.RowCount := StringGrid1.FixedRows +1 ;
    //StringGrid1.ColCount := StringGrid1.FixedCols +1;
    StringGrid1.Cells[StringGrid1.FixedCols, StringGrid1.FixedRows] := '';
    AssignFile(f, OpenDialog1.FileName);
    Reset(f);
    While not EoF(f) do Begin
      ReadLn(f, ZeileS);
      ZeileA := Explode(';', ZeileS);
      Inc(Zeile);
      StringGrid1.RowCount := StringGrid1.FixedRows + Zeile;
      If StringGrid1.ColCount < StringGrid1.FixedCols + Length(ZeileA) Then
        StringGrid1.ColCount := StringGrid1.FixedCols + Length(ZeileA);
      For I := 0 to Length(ZeileA) - 1 do
        StringGrid1.Cells[StringGrid1.FixedCols + I, StringGrid1.FixedRows + Zeile - 1] := ZeileA[I];
    End;
    CloseFile(f);
    label1.Caption:= inttostr(stringgrid1.RowCount);
    label2.caption:= inttostr(stringgrid1.ColCount);
  End;
Möchte ich anschließend diese Felder in einer DB speichern. Hierzu habe ich folgenden Code gefunden und benutzt.
Delphi-Quellcode:
procedure TForm1.Button2Click(Sender: TObject);
var sqry:String;
    y:Integer;
begin
 sqry:='INSERT INTO PLZ (PLZ, ORT, Tour) VALUES(:v1, :v2, :v3)';
 for y:=1 to StringGrid1.RowCount do
  begin
    qrmain.SQL.text:=sqry;
        with qrmain.params do
    begin
      ParamValues['v1']:=StringGrid1.Cells[0, y];
      ParamValues['v2']:=StringGrid1.Cells[1, y];
      ParamValues['v3']:=StringGrid1.Cells[2, y];
    end; // with
    qrmain.ExecSQL;
  end; // for y

end;
Wenn ich diesen Code nun ausführe bekomme ich eine "EGridException" und es wird folgende Codezeile angemeckert.
Delphi-Quellcode:
if (Col<0) or (Row<0) or (Col>=ColCount) or (Row>=RowCount) then
    raise EGridException.CreateFmt(rsIndexOutOfRange, [Col, Row]);
Irgendwas mache ich wohl mit den FixedCols und Fixedrows Angaben falsch. Zum Einlesen der CSV-Datei waren diese beiden um 1 erhöht. Damit kam die andere Prozedur beim Speichern in die Tabelle nicht zu recht. Also habe ich das mal weggelassen und trotzdem klappt es nicht. Bestimmt wieder so ein Schwachsinnsfehler von mir.

Ati
Ich weiß das ich nichts weiß

Sokrates
  Mit Zitat antworten Zitat
 


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 21:32 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 by Thomas Breitkreuz