AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Datenbankabfrage dauert 13 Sekunden

Datenbankabfrage dauert 13 Sekunden

Ein Thema von youuu · begonnen am 15. Sep 2010 · letzter Beitrag vom 15. Sep 2010
Antwort Antwort
Seite 1 von 3  1 23   
youuu

Registriert seit: 2. Sep 2008
Ort: Kleve
822 Beiträge
 
Delphi 2010 Professional
 
#1

Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 15:59
Datenbank: mysql • Version: 5.x • Zugriff über: devart
Hallo,

ich beziehe ca. 4.000 Datensätze aus einer MySQL Tabelle, welche ca. 300.000 Datensätze aufweißt.
Allerdings dauert diese Abfrage 13 Sekunden.
Wie kann ich diese verbessern, ohne vorerst in der MySQL Tabelle selber rum zu fuchteln.

Hier die Abfrage:
Delphi-Quellcode:

  DSListe.TableName := '`links`,`kundendaten`';
  DSListe.FilterSQL := '(links.link_id = data.link_id) and (links.aufrufe <= 2) and (links.eintrag <> ''delete'') and ((links.date = date1) or (links.date = date2))';
DSListe = TUniTable.
Steven
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:00
Nimm besser ein Query. Den so werden alle 300000DS an den Client übertragen und dort gefiltert
Markus Kinzler
  Mit Zitat antworten Zitat
youuu

Registriert seit: 2. Sep 2008
Ort: Kleve
822 Beiträge
 
Delphi 2010 Professional
 
#3

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:09
Sollte eigentlich nicht, denn die Abfrage von UniTable sieht so aus

Delphi-Quellcode:
SELECT * FROM `links`,`kundendaten`
WHERE (links.link_id = data.link_id) and (links.aufrufe <= 2) and (links.eintrag <> ''delete'') and ((links.date = date1) or (links.date = date2))
Steven
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.169 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:20
Wie groß ist die Datenbanktabelle?
Gibt es Indexe auf die Where-Felder?
Wie viel Speicher (RAM) darf sich der Server "genehmigen"
Virenscanner für die DB-Dateien deaktiviert?
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.007 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#5

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:28
Beinhalten die 13 Sekunden auch den Verbindungsaufbau zur Datenbank oder steht die schon vorher?
Nur bei der ersten Ausführung innerhalb einer Session oder jedesmal?
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
generic

Registriert seit: 24. Mär 2004
Ort: bei Hannover
2.415 Beiträge
 
Delphi XE5 Professional
 
#6

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:49
Code:
SELECT * FROM `links`,`kundendaten`
Das ist ein kartesisches Produkt.
Coding BOTT - Video Tutorials rund um das Programmieren - https://www.youtube.com/@codingbott
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.534 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:53
Ohne WHERE-Klausel wäre es das.
SQL-Code:
SELECT * FROM `links`,`kundendaten`
WHERE (links.link_id = data.link_id) ...
Allerdings gehe ich jetzt davon aus, dass es sich um einen C&P-Fehler handelt und data und kundendaten dasselbe sind.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von rollstuhlfahrer
rollstuhlfahrer

Registriert seit: 1. Aug 2007
Ort: Ludwigshafen am Rhein
1.529 Beiträge
 
Delphi 7 Professional
 
#8

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:55
Schneller gehts dann nur mit JOINS. Die brauchen auch wesentlich weniger Server-Ressourcen. Das sieht dann so ähnlich aus: SELECT * FROM `links` INNER JOIN `kundendaten`.`link_id` ON `links`.`link_id` WHERE (links.aufrufe <= 2) and (links.eintrag <> ''delete'') and ((links.date = date1) or (links.date = date2)) Bei deinen Abfragen war übrigens ein Fehler drinnen, der oben beseitigt ist. Wenn du die Tabelle Kundendaten meinst, dann darfst du nicht später diese Tabelle mit data ansprechen. Der MySql-Server sollte diese dann nicht finden. Es würde mich wundern, wenn du mit diesem Query mehr als 1 Ergebnis bekommst (nämlich das Syntax-Fehler-Ergebnis).

Bernhard
Bernhard
Iliacos intra muros peccatur et extra!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 16:58
Zitat:
Schneller gehts dann nur mit JOINS.
Hat er doch, allerdings einen impliziten
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.169 Beiträge
 
Delphi 10.4 Sydney
 
#10

AW: Datenbankabfrage dauert 13 Sekunden

  Alt 15. Sep 2010, 17:05
Code:
SELECT * FROM `links`,`kundendaten`
Das ist ein kartesisches Produkt.
MySQL sollte nicht zusammenbrechen wenn der JOIN im Where ((links.link_id = data.link_id) ) kommt.
Es ist aber sinnvoll die SQL-Join-Syntax zu verwenden.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23   

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 10:47 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