![]() |
Datenbank: MySQL • Version: 5 • Zugriff über: UniDac
Query springt nicht zum ersten Datensatz
Hallo Zusammen,
ich habe ein für mich nicht erklärbares Problem mit einer UniQuery von UniDac. Ich habe alle Einstellungen meiner Software in einer Tabelle gespeichert, mit den Spalten: ID: für den Schlüssel einstellung: um was für eine Einstellung handelt es sich - danach wird auch gesucht wert: das ist der eigentliche Wert der Einstellung kommentar: hier wird die Einstellung die Zusammensetzung der Werte erklärt. Dann habe ich eine Function geschrieben, um die Einstellung schnell abholen zu können, ohne ständig auf die DB zugreifen zu müssen. Das heißt ich halte die Daten in der Query und hole sie bei Bedarf mit der Function Find_Property(einstellung, spalte: string):string raus. Spalte gibt an, aus welcher Spalte der Einstellungswert zu holen ist. Ich habe auch eine Variante, wo eine Einstellung mehrere werte haben kann...
Delphi-Quellcode:
Eigentlich läuft die Funktion gut, aber auf einmal springt sie nicht mehr zum ersten Datensatz, sondern bleibt auf dem letzten stehen.
function TMySQLDB.Find_Property(Einstellung, Spalte: string): string;
var I: integer; begin Result:=''; FQuery_Einstellungen.First; //das scheint wirkungslos zu sein if FQuery_Einstellungen.Bof then begin //zum Testen eingebaut while (not FQuery_Einstellungen.Eof) and (FQuery_Einstellungen.FieldByName('Einstellung').AsString<>Einstellung) do begin FQuery_Einstellungen.Next; end; if FQuery_Einstellungen.FieldByName('Einstellung').AsString=Einstellung then begin Result:=FQuery_Einstellungen.FieldByName(Spalte).AsString; end; end; end; Die Query hat 53 Datensätze, was ich geprüft habe. Hat jemand eine Idee? Vielen Dank Patrick |
AW: Query springt nicht zum ersten Datensatz
Moin...8-)
Delphi-Quellcode:
Ich könnte dir das umschreiben...aber du sollst es allein finden. :thumb:
while (not FQuery_Einstellungen.Eof) and (FQuery_Einstellungen.FieldByName('Einstellung').AsString<>Einstellung) do begin
// <> heißt, wenn die Einstellung nicht gefunden wird, gehe zum nächsten Datensatz...es fehlt die Abbruch Bedingung. :-) FQuery_Einstellungen.Next; // das hast du auch programmiert :-) end; // Am Ende steht der Datensatz auf dem Letzten |
AW: Query springt nicht zum ersten Datensatz
Ich kenne Unidac nicht, aber gibt es da kein Locate o.ä.?
|
AW: Query springt nicht zum ersten Datensatz
Hallo,
Zitat:
Gibt es bei der Query ein Property UniDirectional? Wenn ja, setze das mal auf False. (Müßte es geben: ![]() Zitat:
|
AW: Query springt nicht zum ersten Datensatz
Die Bedingungin der while-Schleife soll eigentlich heißen:
Solange Du nicht am Ende angekommen bist (eof) und Du die Einstellung nicht gefunden hast, dann Query.Next. Damit wird der nächste Datensatz angesprochen. Aber die Query bleibt auf dem letzten Datensatz stehen... |
AW: Query springt nicht zum ersten Datensatz
Wie kommst Du darauf, das First sei wirkungslos?
Wenn man nur Next macht und am Ende angekommen ist, gibt es die Einstellung, die Du suchst halt nicht. |
AW: Query springt nicht zum ersten Datensatz
Zitat:
Zitat:
Zitat:
|
AW: Query springt nicht zum ersten Datensatz
Zitat:
Zitat:
Zitat:
Deshalb wollte ich
Delphi-Quellcode:
nutzen, um zum ersten zu springen und dann die Schleife laufen zu lassen. Aber das bleibt ohne Effekt. Bei debuggen kann ich sehen, dass der Wert des letzten Datensatzes ausgegeben wird....
FQuery_Einstellungen.First
|
AW: Query springt nicht zum ersten Datensatz
keine Lösung, dafür Fragen...
wie sieht der Wert von FQuery_Einstellungen.FieldByName('Einstellung').As String vor und nach FQuery_Einstellungen.First; aus? das schon geprüft? Oder wie stellst Du fest, dass First keine Wirkung hat? Wie ist der Wert von FQuery.SQL.Text beim Eintritt in die Methode? |
AW: Query springt nicht zum ersten Datensatz
Und wenn schon dynamisch per Query, warum machst du nicht gleich eine Query, die genau den gesuchten Wert holt, statt dieses "Gehampel" (zum Glück jetzt nur max. 53 Mal nachschauen und weiterschalten). Wenn es tausende Einstellungen wären, würde man wahrscheinlich gar nicht ert auf die Idee kommen, jeden lokal abzurufen und nachzuschauen, ob es die Einstellung ist, die man eigentlich braucht.
Query.sql.add('where <spalte> = :Einstellung') Ergebnis: Leere Menge = Einstellung gibt's nicht in <spalte> bzw. Tippfehler im Parameter Ergebnis: Ein Datensatz = Treffer Ergebnis: Mehr = nicht eindeutig... > Fehler im Datenmodell |
AW: Query springt nicht zum ersten Datensatz
Zitat:
|
AW: Query springt nicht zum ersten Datensatz
Zitat:
Delphi-Quellcode:
function TMySQLDB.Find_Property(Einstellung, Spalte: string): string;
var I: integer; begin Result := ''; FQuery_Einstellungen.First; while not FQuery_Einstellungen.Eof do begin if FQuery_Einstellungen.FieldByName('Einstellung').AsString = Einstellung then begin Result := FQuery_Einstellungen.FieldByName(Spalte).AsString; Break; end; FQuery_Einstellungen.Next; end; end; |
AW: Query springt nicht zum ersten Datensatz
Zitat:
Wenn man es aber schon mit Schleife macht, wäre es vllt. sinngemäß so einfacher:
Delphi-Quellcode:
Nützt aber natürlich nix, wenn Query.First wirklich nicht funzt wegen unidirectionalem Cursor o.ä.
Result:='Default oder Dummy oder nix';
Query.First while not Query.EOF do begin if Query.FieldByName('Eingabe').AsString='Eingabe' then begin Result:=Query.FieldByName('Angabe').AsString; break; end; Query.Next end; Evtl. kann man die Query nur lokal in der Funktion benutzen und jedes mal neu aufmachen, dann steht sie autom. immer auf dem ersten Datensatz. |
AW: Query springt nicht zum ersten Datensatz
Zitat:
Zitat:
Delphi-Quellcode:
'select * from einstellungen'
Zitat:
Ich weiß nicht warum Query.First keinen Effekt hat. Bislang hatte ich die Wert in ein Array geladen, da funktionierte es natürlich. Aber das musste ich aus einem anderen Grund ändern. So scheint es aber auch zu funktionieren... Ich nach dem Hinweis mit Locate, loacate den Datensatz mit der procedure Query.locate und nehme dann den Wert aus der Spalte 'Spalte'... Anders herum gedacht, sieht aber ganz gut aus und ist sogar einfacher...
Delphi-Quellcode:
Vielen Dank
function TMySQLDB.Find_Property(Einstellung, Spalte: string): string;
begin Result:=''; FQuery_Einstellungen.Locate('einstellung',einstellung,[]); if FQuery_Einstellungen.FieldByName('Einstellung').AsString=Einstellung then begin Result:=FQuery_Einstellungen.FieldByName(Spalte).AsString; end; end; Patrick |
AW: Query springt nicht zum ersten Datensatz
Zitat:
PS: [meine Meinung]Von Locate rate ich ab. Funktioniert mal, mal nicht.[/meine Meinung] |
AW: Query springt nicht zum ersten Datensatz
Zitat:
Vielen Dank Patrick |
AW: Query springt nicht zum ersten Datensatz
Locate sollte eigentlich auch true zurückgeben, wenn der Datensatz gefunden wurde, so dass man auch schreiben kann:
if Query.Locate() then Result:=Query.FieldByName() @haentschman: Kannst du das mit dem Locate-Problemen konkretisieren? Sind das bestimmte Szenarien, wo das nicht geht? Benutze das recht oft (mit TADOQuery allerdings) und hatte noch keine Probleme. |
AW: Query springt nicht zum ersten Datensatz
@Jumpy:
Mein Problem: ![]() Probleme anderer: ![]() |
AW: Query springt nicht zum ersten Datensatz
Hallo,
Zitat:
Die Query wird als Datenspeicher benutzt und muss nur einmal ausgeführt werden. |
AW: Query springt nicht zum ersten Datensatz
Das halte ich für Sparen am falschen Ende. Meiner Meinung nach sollte der Ablauf ungefähr so sein:
Code:
Was der TE tut ist
Hole Parameter1
Hole Parameter2 ... Hole ParameterN
Code:
Der vom TE gewählte Weg ist erst bei einer großen Menge Parametern und/oder einer extrem langsamen DB - Anbindung effizenter.
Hole alle vorhandenen Parameter
Hole aus der Ergebnismenge Parameter1 Hole aus der Ergebnismenge Parameter2 ... Hole aus der Ergebnismenge ParameterN Vor allem der Umgang mit fehlenden Werten ist im zweiten Fall aufwendiger, da es mindestens zwei Orte (DB und Ergebnismenge) gibt an denen geprüft werden muß ob die gewünschten Werte vorhanden sind. Und das gerne genommene
SQL-Code:
kann im ungünstigen Falle so viel überflüssige Daten liefern, daß ein möglicher Performancevorteil aufgezehrt wird.
Select * from...
Gruß K-H |
AW: Query springt nicht zum ersten Datensatz
Zitat:
Jedoch wenn es sich um ca. 50 Einstellungen handelt würde ich jedoch auch keine Query immer beschäftigen. Besser ich lese die Daten aus der DB und schreibe sie in eine Struktur. if Einstellung.Farbe=rot then ... Auch besser lesbar und schneller. |
AW: Query springt nicht zum ersten Datensatz
Zitat:
|
AW: Query springt nicht zum ersten Datensatz
Zitat:
Das mit dem SELECT * FROM ... stimmt natürlich, ist aber die Entscheidung des Programmierers, ob er es langsam oder schnell gestaltet. |
AW: Query springt nicht zum ersten Datensatz
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:41 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-2025 by Thomas Breitkreuz