Inhaltsverzeichnis
Ein Algorithmusoptimierungsproblem für das Agentenverteilungssystem
Frage:
Traverse
Antwortinhalt:
Heim Backend-Entwicklung PHP-Tutorial Datenstruktur – PHPs Problem mit der MySQL-Datenbankdurchquerung

Datenstruktur – PHPs Problem mit der MySQL-Datenbankdurchquerung

Dec 01, 2016 am 01:27 AM
mysql php 数据结构

Ein Algorithmusoptimierungsproblem für das Agentenverteilungssystem

Zum Beispiel sind die Agentenstufen in drei Stufen unterteilt: Gold, Silber und Bronze. Ich bin jetzt Goldagent A. Gleichzeitig habe ich Silberagenten B, C und D entwickelt. Silberagent B hat Bronze entwickelt Agenten E und F, wie in der Abbildung gezeigt:
As untergeordnete Proxy-Liste
╦═══════

╠═ b
║ ╠══ e
║ ╠══ f
╠═ c
╠═ d
Die Methode, die ich verwende, um das obige Beispielbild zu erstellen, ist: (PHP+MYSQL)
Suchen Sie zuerst nach allen Agenten, deren überlegener Agent ist A.
Zum Beispiel habe ich Agent B gefunden und dann nach allen Agenten gesucht, deren überlegener Agent B ist. Diese Suche ist abgeschlossen.
Erneut nach Agent C suchen…………
Und so weiter.

Frage:

Es gibt jetzt 300.000 Datensätze in der Agentendatenbank. Befolgen Sie die oben beschriebene Methode:
Jede Suche dauert lange 1.000 untergeordnete Agenten werden überhaupt nicht angezeigt.


Die Lösung, die ich gefunden habe, besteht darin, ein Array zum Speichern aller Benutzerbeziehungen zu verwenden und dieses Array dann als Datei zu speichern. Jedes Mal, wenn ein Benutzer hinzugefügt oder gelöscht wird, wird das Array gleichzeitig aktualisiert Die gewünschten Daten werden aus dem Array übertragen und dann direkt zur Datenbank weitergeleitet, um eine Auswahl auszuführen. . Ist dieser Ansatz machbar? Gibt es andere Lösungen?


Traverse

Wenn Sie die unteren Mitglieder der oberen Ebene finden möchten, verwenden Sie die Durchquerung visueller Ebenen. Dieser Algorithmus fragt die Datenbank mehrmals visuell ab. . . Es verbraucht zu viele Ressourcen. Gibt es Alternativen? Cache? Redis?

Antwortinhalt:

Ein Algorithmusoptimierungsproblem für das Agentenverteilungssystem

Zum Beispiel sind die Agentenstufen in drei Stufen unterteilt: Gold, Silber und Bronze. Ich bin jetzt Goldagent A. Gleichzeitig habe ich Silberagenten B, C und D entwickelt. Silberagent B hat Bronze entwickelt Agenten E und F, wie in der Abbildung gezeigt:
As untergeordnete Proxy-Liste
╦═══════

╠═ b
║ ╠══ e
║ ╠══ f
╠═ c
╠═ d
Die Methode, die ich verwende, um das obige Beispielbild zu erstellen, ist: (PHP+MYSQL)
Suchen Sie zuerst nach allen Agenten, deren überlegener Agent ist A.
Zum Beispiel habe ich Agent B gefunden und dann nach allen Agenten gesucht, deren überlegener Agent B ist. Diese Suche ist abgeschlossen.
Erneut nach Agent C suchen…………
Und so weiter.

Frage:

Es gibt jetzt 300.000 Datensätze in der Agentendatenbank. Befolgen Sie die oben beschriebene Methode:
Jede Suche dauert lange 1.000 untergeordnete Agenten werden überhaupt nicht angezeigt.


Die Lösung, die ich gefunden habe, besteht darin, ein Array zum Speichern aller Benutzerbeziehungen zu verwenden und dieses Array dann als Datei zu speichern. Jedes Mal, wenn ein Benutzer hinzugefügt oder gelöscht wird, wird das Array gleichzeitig aktualisiert Die gewünschten Daten werden aus dem Array übertragen und dann direkt zur Datenbank weitergeleitet, um eine Auswahl auszuführen. . Ist dieser Ansatz machbar? Gibt es andere Lösungen?


Traverse

Wenn Sie die unteren Mitglieder der oberen Ebene finden möchten, verwenden Sie die Durchquerung visueller Ebenen. Dieser Algorithmus fragt die Datenbank mehrmals visuell ab. . . Es verbraucht zu viele Ressourcen. Gibt es Alternativen? Cache? redis?

Es wird empfohlen, hierarchisch abzufragen und Daten bei Bedarf abzufragen. Das gleichzeitige Anzeigen eines Beziehungsbaums erfordert viele Abfragen und verbraucht Ressourcen.
Eine solche Implementierung kann unendlich viele Klassifizierungsebenen anzeigen. und durchqueren Sie die Baumstruktur der Reihe nach. Die Klassifizierung von Einkaufszentren basiert auf denselben Prinzipien

Überprüfen Sie zunächst, ob der Index auf Proxy-Ebene erstellt wurde.

Es ist nicht sinnvoll, den gesamten Baum auf einer Seite anzuzeigen. Es kann eine On-Demand-Abfrage erfolgen.
Der Gold-Agent öffnet die Seite, um alle Silber-Agenten der Untergebenen anzuzeigen. Klicken Sie auf den Silber-Agenten-Benutzer, um die Bronze-Agenten seiner Untergebenen anzuzeigen.

Vielen Dank für die Einladung, lassen Sie mich einige meiner Ideen mit Ihnen teilen:

  1. Wenn die Aktualisierungen nicht sehr häufig sind, verwenden Sie 缓存 (das Datenvolumen beträgt 300.000 und es wird geschätzt, dass nur die Ebenen 1 bis 2 zwischengespeichert werden können), anstatt jedes Mal eine SQL-Abfrage zu verwenden.

  2. wird mehrmals geladen. Wie oben erwähnt, laden Sie zuerst N级 und dann Ajax, um N+1级 anzufordern.

Baumstruktur-Infinitus-Klassifizierung

Suchen Sie selbst nach der konkreten Antwort. Es ist sehr schwierig, dies im Detail zu erklären. Ich gebe Ihnen das allgemeine Prinzip.
Wie können Sie so schnell wie möglich wissen, wer Ihre Untergebenen sind? Wenn sich alle anstellen, müssen Sie nur zwei Bedingungen erfüllen: 1. Sie wissen, wer der Erste ist. 2. Stellen Sie sicher, dass Sie der Letzte sind. (Natürlich können Sie auch wissen, wer der Letzte ist, und sicherstellen, dass Sie der Erste sind.)
Weisen Sie basierend auf dieser Schlussfolgerung jedem Knoten eine geeignete Seriennummer zu, um eine schnelle Suche zu erreichen, z. B. „select * from tree where indexNumber >= search.node.min && indexNumber <“.

Die endgültige Tabellenstruktur ähnelt

id, parent_id (übergeordneter Knoten), top_id (Wurzelknoten, wenn mehrere Bäume vorhanden sind), indexNumber (Indexnummer im Baum, top_id+indexNumber ist eindeutig), min ( Ich bin der Maßstab, der der Erste unter diesem Zweig ist), Ebene (Baumhöhe)

Für Ihr Beispiel sollte es ähnlich sein (die erste Zahl in Klammern ist die Indexzahl, die zweite ist min, die dritte ist die Baumhöhe)

<code>            a(6,1,0)
     b(3,1,1)      c(4,4,1)      d(5,5,1)
e(1,1,2) f(2,2,2)</code>
Nach dem Login kopieren
Diese Struktur ist beim Betrieb von Knoten komplizierter (wenn Sie beispielsweise ein g nach f hinzufügen oder f löschen, muss abcd die Sequenznummer neu berechnen), aber die Suche ist im Allgemeinen sehr schnell in einer Suche La.

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP und Python: Vergleich von zwei beliebten Programmiersprachen PHP und Python: Vergleich von zwei beliebten Programmiersprachen Apr 14, 2025 am 12:13 AM

PHP und Python haben jeweils ihre eigenen Vorteile und wählen nach den Projektanforderungen. 1.PHP ist für die Webentwicklung geeignet, insbesondere für die schnelle Entwicklung und Wartung von Websites. 2. Python eignet sich für Datenwissenschaft, maschinelles Lernen und künstliche Intelligenz mit prägnanter Syntax und für Anfänger.

PHP: Eine Schlüsselsprache für die Webentwicklung PHP: Eine Schlüsselsprache für die Webentwicklung Apr 13, 2025 am 12:08 AM

PHP ist eine Skriptsprache, die auf der Serverseite weit verbreitet ist und insbesondere für die Webentwicklung geeignet ist. 1.PHP kann HTML einbetten, HTTP -Anforderungen und Antworten verarbeiten und eine Vielzahl von Datenbanken unterstützt. 2.PHP wird verwendet, um dynamische Webinhalte, Prozessformdaten, Zugriffsdatenbanken usw. mit starker Community -Unterstützung und Open -Source -Ressourcen zu generieren. 3. PHP ist eine interpretierte Sprache, und der Ausführungsprozess umfasst lexikalische Analyse, grammatikalische Analyse, Zusammenstellung und Ausführung. 4.PHP kann mit MySQL für erweiterte Anwendungen wie Benutzerregistrierungssysteme kombiniert werden. 5. Beim Debuggen von PHP können Sie Funktionen wie error_reporting () und var_dump () verwenden. 6. Optimieren Sie den PHP-Code, um Caching-Mechanismen zu verwenden, Datenbankabfragen zu optimieren und integrierte Funktionen zu verwenden. 7

Der aktuelle Status von PHP: Ein Blick auf Webentwicklungstrends Der aktuelle Status von PHP: Ein Blick auf Webentwicklungstrends Apr 13, 2025 am 12:20 AM

PHP bleibt in der modernen Webentwicklung wichtig, insbesondere in Content-Management- und E-Commerce-Plattformen. 1) PHP hat ein reichhaltiges Ökosystem und eine starke Rahmenunterstützung wie Laravel und Symfony. 2) Die Leistungsoptimierung kann durch OPCACHE und NGINX erreicht werden. 3) Php8.0 führt den JIT -Compiler ein, um die Leistung zu verbessern. 4) Cloud-native Anwendungen werden über Docker und Kubernetes bereitgestellt, um die Flexibilität und Skalierbarkeit zu verbessern.

Php gegen andere Sprachen: Ein Vergleich Php gegen andere Sprachen: Ein Vergleich Apr 13, 2025 am 12:19 AM

PHP eignet sich für die Webentwicklung, insbesondere für die schnelle Entwicklung und Verarbeitung dynamischer Inhalte, ist jedoch nicht gut in Anwendungen auf Datenwissenschaft und Unternehmensebene. Im Vergleich zu Python hat PHP mehr Vorteile in der Webentwicklung, ist aber nicht so gut wie Python im Bereich der Datenwissenschaft. Im Vergleich zu Java wird PHP in Anwendungen auf Unternehmensebene schlechter, ist jedoch flexibler in der Webentwicklung. Im Vergleich zu JavaScript ist PHP in der Back-End-Entwicklung präziser, ist jedoch in der Front-End-Entwicklung nicht so gut wie JavaScript.

Mysqls Platz: Datenbanken und Programmierung Mysqls Platz: Datenbanken und Programmierung Apr 13, 2025 am 12:18 AM

Die Position von MySQL in Datenbanken und Programmierung ist sehr wichtig. Es handelt sich um ein Open -Source -Verwaltungssystem für relationale Datenbankverwaltung, das in verschiedenen Anwendungsszenarien häufig verwendet wird. 1) MySQL bietet effiziente Datenspeicher-, Organisations- und Abruffunktionen und unterstützt Systeme für Web-, Mobil- und Unternehmensebene. 2) Es verwendet eine Client-Server-Architektur, unterstützt mehrere Speichermotoren und Indexoptimierung. 3) Zu den grundlegenden Verwendungen gehören das Erstellen von Tabellen und das Einfügen von Daten, und erweiterte Verwendungen beinhalten Multi-Table-Verknüpfungen und komplexe Abfragen. 4) Häufig gestellte Fragen wie SQL -Syntaxfehler und Leistungsprobleme können durch den Befehl erklären und langsam abfragen. 5) Die Leistungsoptimierungsmethoden umfassen die rationale Verwendung von Indizes, eine optimierte Abfrage und die Verwendung von Caches. Zu den Best Practices gehört die Verwendung von Transaktionen und vorbereiteten Staten

Die dauerhafte Relevanz von PHP: Ist es noch am Leben? Die dauerhafte Relevanz von PHP: Ist es noch am Leben? Apr 14, 2025 am 12:12 AM

PHP ist immer noch dynamisch und nimmt immer noch eine wichtige Position im Bereich der modernen Programmierung ein. 1) Einfachheit und leistungsstarke Unterstützung von PHP machen es in der Webentwicklung weit verbreitet. 2) Seine Flexibilität und Stabilität machen es ausstehend bei der Behandlung von Webformularen, Datenbankoperationen und Dateiverarbeitung; 3) PHP entwickelt sich ständig weiter und optimiert, geeignet für Anfänger und erfahrene Entwickler.

PHP vs. Python: Kernmerkmale und Funktionen PHP vs. Python: Kernmerkmale und Funktionen Apr 13, 2025 am 12:16 AM

PHP und Python haben jeweils ihre eigenen Vorteile und eignen sich für verschiedene Szenarien. 1.PHP ist für die Webentwicklung geeignet und bietet integrierte Webserver und reichhaltige Funktionsbibliotheken. 2. Python eignet sich für Datenwissenschaft und maschinelles Lernen mit prägnanter Syntax und einer leistungsstarken Standardbibliothek. Bei der Auswahl sollte anhand der Projektanforderungen festgelegt werden.

Zweck von PHP: Erstellen dynamischer Websites Zweck von PHP: Erstellen dynamischer Websites Apr 15, 2025 am 12:18 AM

PHP wird verwendet, um dynamische Websites zu erstellen. Zu den Kernfunktionen gehören: 1. Dynamische Inhalte generieren und Webseiten in Echtzeit generieren, indem Sie eine Verbindung mit der Datenbank herstellen; 2. Verarbeiten Sie Benutzerinteraktions- und Formulareinreichungen, überprüfen Sie Eingaben und reagieren Sie auf Operationen. 3. Verwalten Sie Sitzungen und Benutzerauthentifizierung, um eine personalisierte Erfahrung zu bieten. 4. Optimieren Sie die Leistung und befolgen Sie die Best Practices, um die Effizienz und Sicherheit der Website zu verbessern.

See all articles