php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 12.06.2011, 19:33  
Neuer Benutzer
 
Registriert seit: 12.06.2011
Beiträge: 1
PHP-Kenntnisse:
Fortgeschritten
klausinge befindet sich auf einem aufstrebenden Ast
Standard Komplexe Abfrage mit Postleitzahlen

Hallo alle zusammen,

das ist mein erster Beitrag hier und ich hoffe dass ich hier einige Tipps bekomme.

Zu meinem Problem. Ich habe eine Tabelle mit allen Postleitzahlen aus Deutschland.

Bei meinem Projekt meldet der Benutzer sich an und gibt dazu seine PLZ an und einen Radius in km aus dem er Anfragen möchte.


Aus diesen Daten lade ich mir mit:

PHP-Code:
$plz 01069;
        
// der Umkreis in Km
$umkreis 10;

// Erdradius (geozentrischer Mittelwert) in Km
$radius 6368;
        
// Geodaten zu meiner PLZ laden
$radiusPLZ $db->select("SELECT geo_l, geo_b FROM plz WHERE plz = '$plz'");
        
// Umrechnung von GRAD IN RAD
$rad_l $radiusPLZ[0]["geo_l"] / 180 M_PI;
$rad_b $radiusPLZ[0]["geo_b"] / 180 M_PI;
        
// jetzt erfolgt die eigentliche Abfrage
// Alle PLZ laden die für meinen Umkreis relevant sind
$query "SELECT plz.plz FROM plz WHERE 
             "
.$radius." * SQRT(2*(1-cos(RADIANS(geo_b)) * 
         cos("
.$rad_b.") * (sin(RADIANS(geo_l)) * 
         sin("
.$rad_l.") + cos(RADIANS(geo_l)) * 
         cos("
.$rad_l.")) - sin(RADIANS(geo_b)) * sin(".$rad_b."))) <= ".$umkreis;

$daten $db->select($query); 
Dies funktioniert auch und ich bekomme die PLZ alle ins Array geschrieben.

NUn der nächste Schritt. Der Benutzer kann mehere Dienstleistungen auswählen z.B. D1, D2, D3 usw. Jede Dienstleistung wird mit einen Preis belegt.


Nun können Anfragen erstellt werden, welche wie folgt aufgebaut sind:

$dienstleistung = 1; (Steht für D1 - die 1 ist die id aus der tabelle)
$preis = 100;
$plz = 01309;

NUn möchte ich den Benutzer alle Anfragen anzeigen, welche von seiner PLZ und seinen Radius zutreffen.

Bei einem Umkreis von 10 km mag das noch gehen, da sind es wie in diesem Beispiel 26 (PLZ) x 3 (Dienstleistungen)

Diese lasse ich in einer Schliefe nun durchlaufen und den Query erstellen.

PHP-Code:
$Query.= "(d.dienst = $dienstleistung AND d.preis >= $preis AND d.plz = $plz)"
In dem Beispiel würde ich nun 78 mal OR in dem Query stehen haben. Das geht noch. Wenn ich nun den Umkreis auf 500 km setze, dann habe ich ca. 5000 PLZ x 3 Dienstleistungen = 15.000 mal OR in einer Abfrage. Die Dienstleistungen sind auch variabel, es können 3 sein, 2 oder auch 20. Entsprechend verändert sich der Wert.

Hat dazu jemand eine Idee, wie man das am optimalsten umsetzen könnte? Weil mit 15.000 OR in einer Abfrage bekomme ich nur Fehlermeldungen.

Gruß Klaus
klausinge ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 12.06.2011, 20:37  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

Wenn Du 15 unabhängige Dienstleisten abfragst, dann müssen die halt in die Query. Bis auf IN() gibts da kaum Optimierungspotential.

Zitat:
5000 PLZ x 3 Dienstleistungen
Sorry, aber: Warum? Mach einen JOIN von Deinem Plz-Code und fertig ist.
__________________
--
One pixel is still too big. Please make it smaller. ASAP.

Initiative Mittelstand.
Die wichtigste Gestaltungsregel im Screendesign ist Pi mal Daumen des Arbeitgebers.
--
nikosch ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

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 an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Abfrage von einer Abfrage Datenbanken 5 27.01.2011 23:31
Problem mit Abfrage - join, inner join, distinct? Gachet01 Datenbanken 2 27.01.2011 06:49
False Abfrage und SQL hängt sich auf marc77 Datenbanken 4 22.11.2010 14:57
Optimierung einer Abfrage eines Datensatzes samt Vorgänger und Nachfolger Sirke Datenbanken 7 28.04.2010 17:11
Komplexe Abfrage mit AND und OR Extremefall PHP Tipps 2010 2 14.03.2010 10:24
result Variablen von SQL verbinden vci PHP Tipps 2010 15 05.02.2010 19:09
Scriptsuche [Erledigt] SQL- Abfrage über 2 tabellen ejim Scriptbörse 1 17.07.2009 21:10
Komplexe Abfrage andizo Datenbanken 4 18.04.2009 20:23
Wiemache ich eine Abfrage über 3 Tabellen??? djscaleo Datenbanken 8 05.01.2009 10:46
MySQL - Fehler in einfacher Abfrage oden Datenbanken 11 03.01.2009 20:03
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
[Erledigt] IF() abfrage in variable packen PHP Tipps 2005 14 01.04.2005 17:23
Abfrage von Char-Feldern Datenbanken 9 04.02.2005 14:06
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
plz radius, postleitzahlen radius, postleitzahl radius, radius plz, plz tabelle, // erdradius (geozentrischer mittelwert) in km, radius postleitzahlen, postleizahlenabfrage, postleitzahl radius berechnen, postleitzahlen php, plz radius berechnen php, plz deutschland radius, radius berechnen plz, postleitzahlen innerhalb radius, radius nach postleitzahlen, postleitzahlen radiu, postleitzahl php, geozentrischer mittelwert des erdradius, radius von plz, plz tapelle

Alle Zeitangaben in WEZ +2. Es ist jetzt 12:05 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum