AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi TADODataSet -> Enthält nur ein Datensatz
Thema durchsuchen
Ansicht
Themen-Optionen

TADODataSet -> Enthält nur ein Datensatz

Ein Thema von Andi1985 · begonnen am 29. Nov 2007 · letzter Beitrag vom 30. Nov 2007
Antwort Antwort
Benutzerbild von Andi1985
Andi1985

Registriert seit: 11. Mai 2007
Ort: NRW
116 Beiträge
 
Delphi 2006 Enterprise
 
#1

TADODataSet -> Enthält nur ein Datensatz

  Alt 29. Nov 2007, 15:31
Hallo,

vermutlich ist foglendes Problem total simple, ich komm nur derzeitig nicht drauf.

Ich habe mir eine Klasse geschrieben die eine Verbindung zur Datenbank aufbaut
und eine Memberfunktion schickt ein Query raus und speichert die Daten in einem TADODataSet inerhalb
der Klasse.
Wenn ich nun dieses DataSet per Memberfunktion an mein Hauptprogramm übergebe, erhalte ich immer
nur einen Datensatz... (.Next springt sofort auf EOF).

vieleicht könnt ihr mir ja helfen, ich vermute das Problem hat was mit Zeigern in Delphi zu tun.

Delphi-Quellcode:
type
cMyADOConnection = class(TObject)
private
        ...
        var DataSet: TADODataSet;
        ...
public
        ...
        function get_DataSet(): TADODataSet;
        ...
end;
Delphi-Quellcode:
function cMyADOConnection.get_DataSet(): TADODataSet;
begin
        get_DataSet := DataSet;
end;
Hauptprogramm
myDataSet := connection.get_DataSet(); mfg
Moggy
  Mit Zitat antworten Zitat
Benutzerbild von Andi1985
Andi1985

Registriert seit: 11. Mai 2007
Ort: NRW
116 Beiträge
 
Delphi 2006 Enterprise
 
#2

Re: TADODataSet -> Enthält nur ein Datensatz

  Alt 30. Nov 2007, 14:48
Ich konnte das Problem folgendermaßen umgehen, vielen dank, damit kann der Thread geschlossen werden.

DataSet.RecordSet := connection.get_DataSet().RecordSet.Clone(adLockUnspecified);
  Mit Zitat antworten Zitat
shmia

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

Re: TADODataSet -> Enthält nur ein Datensatz

  Alt 30. Nov 2007, 16:52
Na ich weiss nicht, ob deine Lösung so toll ist.
Delphi-Quellcode:
cMyADOConnection = class(TObject)
private
        ...
        var DataSet: TADODataSet; // ***
        ...
public
        ...
        function get_DataSet(): TADODataSet;
        ...
end;
Es sollte klar sein, dass mit obigem Code nur ein einziges Dataset möglich ist.
Die Variable (markiert mit ***) muss weg und get_DataSet() sieht im Prinzip so aus:
Delphi-Quellcode:
function cMyADOConnection.get_DataSet(): TADODataSet;
begin
   result := TADODataSet.Create(nil);
   result.Connection := ...
end;
So wird bei jedem Aufruf ein neues Dataset erzeugt.
Aber Vorsicht, der Aufrufen muss das Objekt freigeben, sonst Speicherleck.
Besser wäre:
Delphi-Quellcode:
cMyADOConnection = class(TObject)
private
        ...
public
        ...
        // der Aufrufer muss das Dataset bereitstellen und auch freigeben
        procedure Setup_DataSet(ds:TADODataSet);
end;
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 02:57 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