Heim > Backend-Entwicklung > PHP-Tutorial > Geospatial -Suche mit Solr und Solarium

Geospatial -Suche mit Solr und Solarium

William Shakespeare
Freigeben: 2025-02-19 08:41:13
Original
841 Leute haben es durchsucht

Dieser Artikel befasst sich mit der Geospatial -Suche in Apache Solr und seiner Interaktion mit der Solarium -PHP -Bibliothek. Solr, ein leistungsstarker Suchservice, bietet Funktionen wie Facettensuche und Ergebnis -Hervorhebung. Solarium vereinfacht die Solr -Integration in PHP -Anwendungen. Dieser Artikel konzentriert sich auf Geospatial-Suchfunktionen, die für standortbasierte Abfragen in Sektoren wie Immobilien und Logistik entscheidend sind.

Geospatial Search with SOLR and Solarium

Schlüsselkonzepte:

  • standortbasierte Suchanfragen: Solr und Solarium ermöglichen effiziente Suchanfragen nach Dokumenten innerhalb eines bestimmten Radius eines bestimmten Punktes.
  • Schema-Konfiguration: Implementieren der Geospatial-Suche erfordert Anpassungen an Solrs schema.xml, einschließlich der Definition eines location -Feldentyps mit Subfeldern mit Breitengrad und Längengrad.
  • Solariums Rolle: Die Solariumbibliothek vereinfacht die Geospatial -Abfragekonstruktion und abstrakte komplexe Solr -Syntax. Es bietet Helferfunktionen für die Entfernungsfilterung und die Proximitätssortierung.
  • Beispielanwendung: Eine praktische Demonstration zeigt, dass Flughäfen mit Solr und Solarium in der Nähe von Flughäfen finden, die Schema -Setup, Datenzuweisung und Suchfunktionen veranschaulichen.
  • Leistungsoptimierung: Techniken wie die Verwendung des "Bbox" -Filters (schneller, weniger präzise) oder des Feldtyps "RPT" (Hochleistungsstufe für große Datensätze) Verbessert die Geospatial-Such-Effizienz.

Geospatiale Suche erklärt:

Geospatial Search befasst sich mit der Suche nach geografisch lokalisierten Elementen. Das Finden von "italienischen Restaurants" ist hilfreich, aber die Spezifikation "italienische Restaurants in 5 Meilen" fügt einen entscheidenden Kontext hinzu. Dies beinhaltet die Verwendung von Breiten- und Längengradkoordinaten, um Punkte auf der Welt zu definieren.

Die Beispielanwendung verwendet drei Methoden, um den Suchursprung zu bestimmen: HTML5-Geolocation (Browser-basierter Standort), eine vordefinierte Liste von Städten und manuelle Longitude-Eingabe.

Schema -Setup:

Ermöglichung von Geospatialfähigkeiten in Solr erfordert Änderungen zu schema.xml. Ein location -Feldentyp wird unter Verwendung der solr.LatLonType -Klassel mit Breitengrad und Längengrad als Unterfelder (tdouble -Typ) hinzugefügt. Ein entsprechendes Feld (z. B. latlon) wird definiert, um die Standortdaten zu speichern, und ein dynamisches Feld behandelt die Breiten- und Längengradkomponenten. Ein Beispiel schema.xml ist im Repository der Beispielanwendung enthalten.

Zuweisen von Speicherortdaten:

Standortdaten werden im Format {latitude},{longitude} zugewiesen. Mit Solarium wird dies mit: $doc->latlon = doubleval($latitude) . "," . doubleval($longitude);

erreicht

Geospatiale Abfragen mit Solarium:

Solariumshelfer vereinfachen die Erstellung der Abfrage. Ein Abstandsfilter wird unter Verwendung von $helper->geofilt() hinzugefügt, wobei Feld, Breitengrad, Länge und Entfernung angegeben werden. Der geodist() Helfer berechnet Entfernungen und Aliase (z. B. _distance_) helfen dabei, Entfernungen in den Ergebnissen abzurufen. Die Sortierung nach Entfernung erfolgt mit $query->setQuery('{!func}' . $helper->geodist(...)) und $query->addSort('score', 'asc');.

Beispielanwendung:

Das bereitgestellte Github-Repository (Link für Kürze weggelassen) enthält eine silex- und twig-basierte Anwendung, die eine geospatiale Suche nach nahe gelegenen Flughäfen unter Verwendung von Daten von OpenFLIGHTS.org zeigt. Das Datenpopulationsskript ist ebenfalls enthalten. Die Anwendung verfügt über ein Suchformular mit Standorteingabeoptionen (Geolokalisierung, Stadtauswahl, manueller Eingabe) und Entfernungsauswahl. In den Suchergebnissen werden Flughafennamen, Städte, Länder und Entfernungen angezeigt.

Schlussfolgerung:

Dieser Artikel bietet einen umfassenden Leitfaden zur Implementierung der Geospatial -Suche mit Solr und Solarium. Die Beispielanwendung zeigt die praktische Implementierung und zeigt, wie textbasierte und geospatiale Suche nach raffinierteren Ergebnissen kombiniert werden.

häufig gestellte Fragen (FAQ): (Der ursprüngliche FAQ -Abschnitt wird in seiner Gesamtheit beibehalten, da es wertvolle ergänzende Informationen liefert.)

Welche Bedeutung hat die Geospatial -Suche in Solr und Solarium?

Wie handelt es sich bei Solr mit Geospatialdaten?

Wie kann ich eine Geospatial -Suche in Solarium ausführen?

Was ist der Unterschied zwischen "GeoFilt" und "Bbox" -Filtern in Solarium?

Wie kann ich Dokumente nach Entfernung in Solr?

sortieren

Kann ich eine geospatiale Suche in mehreren Feldern in Solr?

durchführen

Wie kann ich die Leistung der Geospatial -Suche in Solr?

verbessern

Welche Rolle spielt der „SpatialRecursiveprefixTeefieldType“ in Solr?

Wie handelt es sich bei Solr, mit mehrfach bewertetem Standort Felder?

Kann ich eine geospatiale Suche mit anderen Arten der Suche in Solr?

verwenden

Die Antworten auf diese FAQs sind in der ursprünglichen Eingabe enthalten und werden hier für die Kürze nicht wiederholt.

Das obige ist der detaillierte Inhalt vonGeospatial -Suche mit Solr und Solarium. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage