AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken vergleichbaren SQL-Befehl für "Locate"
Thema durchsuchen
Ansicht
Themen-Optionen

vergleichbaren SQL-Befehl für "Locate"

Ein Thema von Crowbar · begonnen am 7. Jul 2014 · letzter Beitrag vom 7. Jul 2014
Antwort Antwort
Seite 2 von 2     12   
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#11

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 14:08
Nein, das dürfte theoretisch keinen Unterschied machen.
Markus Kinzler
  Mit Zitat antworten Zitat
jensw_2000
(Gast)

n/a Beiträge
 
#12

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 14:22
Die Query und die Table arbeiten grundsätzlich gleich. Sie holen sich standardmäßig alle Datensätze aus einer Tabelle/Abfragedatenmenge in den RAM. Daher sind sie auch grundsätzlich gleich schnell. Bei der Query hast Du jedoch den Vorteil, dass Du die Anzahl der gefetchten Datensätze per WHERE Klausel auf das Notwendige beschränken kannst. Zudem kannst Du die abzurufenden Felder (Spalten) einschränken. (Statt SELECT * FROM die tatsächlich benötigten Feldnamen angeben). Das kann unter dem Strich viel ausmachen.

TTable und TQuery hatten glaube ich eine "UniDirectional" Property.
Hast Du die auf True gesetzt?
Damit kann Deine Suche z.B. vom aktuellen Datensatz direkt zum Anfang springen und eine neue Suche beginnen.
Oder rückwärts navigieren oder .... Vieles mehr.
Das bringt u.U. schon viel.
Falls UniDirectional auf False steht, wird die geftechte Datenmenge immer vom aktuellen Datensatz bis zum Ende durchlaufen. Erst dann beginnt die neue Suche, beginnend vom ersten Datensatz.
Gerade bei großen Tabellen macht sich das unidirektionale Verhalten positiv bemerkbar.

Geändert von jensw_2000 ( 7. Jul 2014 um 14:34 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#13

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 14:58
Den wesentlichen Unterschied hast Du unterschlagen, die TQuery enthält die Daten, so wie sie durch den SQL.Text vorgegeben sind, die TTable kann nur mit einer Tabelle umgehen.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.139 Beiträge
 
Delphi 12 Athens
 
#14

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 15:33
Hat er doch gesagt, wenn man nicht filtert, oder sonstewas, dann ist das praktisch gleich.
SELECT * FROM table

Nur daß man beim Query eben auch noch Spalten und Zeilen filtern kann um nur das Nötige übertragen zu müssen. (filtern, sortieren, gruppieren, joinen uvm.)
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu ( 7. Jul 2014 um 15:35 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#15

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 15:36
Dieses
Code:
select * from table
ist aber eher der Spezialfall

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.139 Beiträge
 
Delphi 12 Athens
 
#16

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 15:44
Kommt drauf an.

select * from myview (oder eine Funktion, welche ein RecordSet liefert)
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#17

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 15:49
In dBase?
Markus Kinzler
  Mit Zitat antworten Zitat
jensw_2000
(Gast)

n/a Beiträge
 
#18

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 15:50
Den wesentlichen Unterschied hast Du unterschlagen, die TQuery enthält die Daten, so wie sie durch den SQL.Text vorgegeben sind, die TTable kann nur mit einer Tabelle umgehen.
Hier ging es nur um eine allgemeine Performance Betrachtung (s. Post #10).
Das man bei der Query die zu fetchende Datenmenge durch Feld-/Datenselektion reduzieren kann hatte ich erwähnt. (s. Post #12)

Dieses
Code:
select * from table
ist aber eher der Spezialfall
Ein Spezialfall, den der Fragesteller offenbar benutzt (s. Post #1).

Boh, was habe ich Dir nur angetan. Ich entschuldige mich pauschal für Alles.
Peace!
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#19

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 16:34
Boh, was habe ich Dir nur angetan. Ich entschuldige mich pauschal für Alles.
Peace!
Ähh? nichts?!
hab ich so bissig geklungen??

vorsichtshalber nehm ich alles zurück was ich geschrieben habe.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
jensw_2000
(Gast)

n/a Beiträge
 
#20

AW: vergleichbaren SQL-Befehl für "Locate"

  Alt 7. Jul 2014, 16:41
Vielleicht bin ich heute auch nur ein bisschen zu sensibel. *schluchz*
Alles wieder gut!
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 00:18 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