Delphi-PRAXiS
Seite 2 von 3     12 3      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi ADO Zugriff mit Fehler (https://www.delphipraxis.net/162874-ado-zugriff-mit-fehler.html)

Union 8. Sep 2011 13:12

AW: ADO Zugriff mit Fehler
 
Abfrage -> Neu -> Neue Abfrage Entwurfsansicht wählen (evtl. mal ein paar Felder einfügen) -> Ansicht (Hauptmenü) -> SQL-Ansicht

Kevin11 8. Sep 2011 13:54

AW: ADO Zugriff mit Fehler
 
So jetzt habe ich gemerkt, dass die Abfrage durchgeht. Jetzt habe ich Probleme mit arrays.

Delphi-Quellcode:
   
var
  Abteilung : array of string;
  i : Integer;
begin
    while not Form2.ADOQuery1.Eof do
        begin
//          Form2.Memo1.Lines.Add(IntToStr(count));
//          Abteilung := Form2.ADOQuery1.FieldByName('Abteilung').Value;
          Form2.ADOQuery1.Next;

        end;
        Form2.ADOQuery1.Close;

      for i := 0 to count do
      begin
        Abteilungsnummer[i] := AddAbt(Abteilung[i]);
      end;
end.
Warum geht das nicht?

DeddyH 8. Sep 2011 13:56

AW: ADO Zugriff mit Fehler
 
Für dynamische Arrays musst Du zunächst mit SetLength() Speicher reservieren.

Union 8. Sep 2011 14:03

AW: ADO Zugriff mit Fehler
 
Oder verwende TStringList. Ausserdem solltest Du bei Datenmengen while not eof verwenden. Wie positionierst Du denn in AddAbt() ? Und um die Sätze zu zählen verwende die Query-Eigenschaft RecordCount.

Delphi-Quellcode:
var
  Abteilung : TStringList;
begin
    Abteilung := TStringList.Create;
    while not Form2.ADOQuery1.Eof do
    begin
       Abteilung.Add(Form2.ADOQuery1.FieldByName('Abteilung').AsString;
       Form2.ADOQuery1.Next;
    end;
    Form2.ADOQuery1.Close;
    Abteilung.Free;
end;
end.

Kevin11 8. Sep 2011 14:22

AW: ADO Zugriff mit Fehler
 
Danke. Was ist daran dann bitte dynamisch? Aus PHP bin ich das richtige dynamische Array gewohnt, deswegen die Frage.

Union 8. Sep 2011 14:28

AW: ADO Zugriff mit Fehler
 
Dynamisch deswegen weil die Größe zur Laufzeit (eben mit SetLength) geändert werden kann. Sinnvollerweise macht man das nicht oft, da es sonst Performanceprobleme geben kann.

DeddyH 8. Sep 2011 14:31

AW: ADO Zugriff mit Fehler
 
Ein statisches Array definiert bereits zur Entwurfszeit die Anzahl der enthaltenen Elemente, ein dynamisches nicht.
Delphi-Quellcode:
var
  StatArray: array[1..10] of string; //statisches Array mit 10 Elementen
  DynArray: array of string; //dynamisches Array, Anzahl der Elemente wird zur Laufzeit festgelegt

Kevin11 8. Sep 2011 16:30

AW: ADO Zugriff mit Fehler
 
Ich hab den Fehler, es ist das
Delphi-Quellcode:
DINSTINCT
. Keine Ahnung warum aber ohne geht es :)

DeddyH 8. Sep 2011 16:32

AW: ADO Zugriff mit Fehler
 
War das gerade ein Tippfehler? Wenn nicht, isses ja klar, das heißt DISTINCT.

haentschman 8. Sep 2011 21:34

AW: ADO Zugriff mit Fehler
 
Zitat:

Form2.ADOQuery1.SQL.Text := 'SELECT DISTINCT ("Abteilung") FROM Mitarbeiter';
...Tippfehler, siehe 1. Post


Alle Zeitangaben in WEZ +1. Es ist jetzt 13:04 Uhr.
Seite 2 von 3     12 3      

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