php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > SQL / Datenbanken
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


SQL / Datenbanken Probleme mit SQL? Hier könnt ihr eure Fragen zu SQL (MySQL, PostgreSQL, MS-SQL und andere ANSI-SQL Server) los werden.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 04-04-2005, 15:09
Sebastian W
 Member
Links : Onlinestatus : Sebastian W ist offline
Registriert seit: Dec 2002
Ort: München
Beiträge: 295
Sebastian W ist zur Zeit noch ein unbeschriebenes Blatt
Standard [MySQL 4.0] Performance

Hallo,

ich habe eine Tabelle mit 91 Spalten und ca. 40.000 Daten.
Für diese Tabelle gibt es eine sehr umfangreiche Suche mit allen Spaltentypen für die Suchoptionen zur Auswahl.

Das Sucheregebnis soll später als CVS exportiert werden. Bei einigen 1000 Daten macht das auch keine Probleme. Jedoch bei ca. 30.000 Suchergebnissen ist die Export funktion einfach zu langsam.

Momentan mach ich es so das die IDs des Suchergebnisse in einer Session gespeichert werden. Auf der Export Seite werden die IDs dann in ein Query umgewandelt. Ergebniss sieht dann so aus:

SELECT * (statt * 91 Spaltennamen) FROM tabelle WHERE id IN(1,2,4,5 etc.) ORDER BY datum

Einen Index habe ich über beide Spalten (id und datum) angelegt. Dieser wird auch von MySQL genutzt, allerdings ist das ganze trotzdem noch zu langsam (ca. 30 Seks.).

Hab deswegen statt die IDs in die Session zu speichern, nun den WHERE Teil aus der Suche in der SESSION gespeichert. Ein Query sieht deswegen jetzt so aus:

SELECT * FROM tabelle WHERE spalte1 = 'ENUMEINTRAG' AND geb => '1950-01-01' AND geb <= '2000-01-01' (könnten auch mehr Spalten sein) ORDER BY datum

Ohne ORDER BY datum wird das ganze auch in weniger als 1 Sekunde abgearbeitet. Mit dem ORDER BY dauert es allerdings ca. 30 Sekunden. Index habe ich über drei Spalten angelegt: spalte1_geb_datum. Dieser wird auch von MySQL genutzt (EXPLAIN):

table
tabelle

type
ref

possible_keys
spalte1_geb_datum

key
spalte1_geb_datum

key_len
1

ref
const

rows
20322

Extra
Using where; Using temporary; Using filesort


Hat jemand eine Idee wie sich das ganze beschleunigen läßt?
__________________
Grüsse,
Sebastian


Profil Flex Freelancer
Twitter twitter.com/flashhilfe
Web Flash und Flex Community
Mit Zitat antworten
freelancermap.de - IT Projektvermittlung für Selbständige und Freiberufler
  #2 (permalink)  
Alt 05-04-2005, 09:35
asp2php
 Banned
Links : Onlinestatus : asp2php ist offline
Registriert seit: Feb 2004
Beiträge: 11.745
asp2php ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Ja, normalisieren, denn 91 Spalten ist bestimmt nicht optimal
Mit Zitat antworten
  #3 (permalink)  
Alt 05-04-2005, 10:26
Sebastian W
 Member
Links : Onlinestatus : Sebastian W ist offline
Registriert seit: Dec 2002
Ort: München
Beiträge: 295
Sebastian W ist zur Zeit noch ein unbeschriebenes Blatt
Standard



Doch ist es. Gibt ja noch mehrere Tabellen die sich auf diese beziehen. Wenn man 91 Daten manuel eintragen muß, bleibt einem wohl nicht viel übrig als 91 Spalten anzulegen. Das bringt mir nichts das auf mehrere Tabellen auszulegen. Sind eh fast alles nur ENUM Felder. - die Angaben stammen aus einem riesigen "Kontakt" Formular.

Hab die Anfrage jetzt auf mehrere "Seiten" aufgeteilt. - 10.000 Datensätze pro Seite



Was würdest du machen wenn du ein Formular mit über 91 Angaben hast?

Abgesehen davon ist die eigentliche Abfrage in weniger als 0.01 Sekunden ausgeführt. Auch bei über 40.000 Daten. Nur das sortieren der Spalte nach dem Datum dauert so lange. Was macht es da für einen Unterschied wenn die Tabelle nur 10 Spalten hätte?
__________________
Grüsse,
Sebastian


Profil Flex Freelancer
Twitter twitter.com/flashhilfe
Web Flash und Flex Community

Geändert von Sebastian W (05-04-2005 um 10:29 Uhr)
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre 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 an


PHP News

PHP Marktplatz-Software
PHP Marktplatz-SoftwareEs hat sich viel getan! Die neue Version 7.5.9 unserer PHP Marktplatz-Software ebiz-trader steht ab sofort zur Verfügung.

28.10.2019 | Berni

Die RIGID-FLEX-Technologie
Die RIGID-FLEX-TechnologieDie sogenannte "Flexible Elektronik" , oftmals auch als "Flexible Schaltungen" bezeichnet, ist eine zeitgemäße Technologie zum Montieren von elektronischen Schaltungen.

06.12.2018 | Berni


 

Aktuelle PHP Scripte

SMT

Server Monitoring & Management Tool Das SMT wurde von einem Administrator für Administratoren entwickelt, es vereinfacht den Alltag in der klassischen Administration und Verwaltung. Mit dem SMT kannst Du alle Deine Server & Dienste verwalten und überwach

04.09.2020 palle_1977 | Kategorie: PHP
numaeks Web-Farbmixer

Die RGB-Farben lassen sich hier auf unterschiedliche Weise mischen. Zur Einstellung werden auch die Dreh- und Schieberegler mit Canvas verwendet. Gespeichert werden die Farben in einem Cookie.

04.09.2020 numaek | Kategorie: JAVASCRIPT/ Tools
phplinX-Erotikportal 4 ansehen phplinX-Erotikportal 4

Erweiterbares Portal speziell für Erotik mit den Modulen Webkatalog, Bannermanagement und Kleinanzeigenmarkt. Sämtliche Module können über einen einzigen Adminbereich verwaltet werden.

18.06.2020 Cosinus14 | Kategorie: PHP/ Anzeigenmarkt
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 16:15 Uhr.