


Datenstruktur – PHPs Problem mit der MySQL-Datenbankdurchquerung
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:
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.wird mehrmals geladen. Wie oben erwähnt, laden Sie zuerst
N级
und dann Ajax, umN+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 <“.
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)
<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>

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen





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 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

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 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.

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

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 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.

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.
