Einschränkungen bei der Verwendung von Unterabfragen in der FROM-Klausel in Ansichten in Versionen vor MySQL 8.0
In MySQL-Versionen vor Version 8.0 gab es eine Einschränkung beim Erstellen von Ansichten, die Unterabfragen in der FROM-Klausel enthielten. Diese Einschränkung ergibt sich aus den zugrunde liegenden Abfrageoptimierungsalgorithmen, die von MySQL verwendet werden.
Lösung
Um diese Einschränkung zu überwinden, ziehen Sie die folgenden Problemumgehungen in Betracht:
-
Erstellen Sie eine materialisierte Ansicht: Eine materialisierte Ansicht ist eine vorberechnete Ansicht, die die Ergebnisse einer Abfrage in einer separaten Tabelle speichert. Durch die Verwendung einer materialisierten Ansicht können Sie die Verwendung einer Unterabfrage in der FROM-Klausel der Ansicht vermeiden.
-
Temporäre Tabellen verwenden: Temporäre Tabellen können zum Speichern der Ergebnisse von Unterabfragen verwendet werden. Auf abgeleitete Tabellen aus Unterabfragen kann in der FROM-Klausel der Ansicht verwiesen werden. Am Ende der Sitzung wird die temporäre Tabelle automatisch gelöscht.
-
Abfrage in mehrere Ansichten aufteilen: Bei komplexen Unterabfragen können Sie die Abfrage in mehrere Ansichten aufteilen. Auf jede Ansicht kann dann von der Hauptansicht verwiesen werden, ohne dass eine Unterabfrage in der FROM-Klausel verwendet werden muss.
Einschränkungen der Lösung
Die oben genannten Lösungen weisen einige Einschränkungen auf:
- Materialisierte Ansichten erfordern zusätzliche Ressourcen und Wartungsaufwand.
- Temporäre Tabellen beeinträchtigen die Leistung, da sie im Speicher gespeichert werden.
- Das Aufteilen von Abfragen kann zu Codekomplexität und Problemen bei der Wartbarkeit führen.
Beispielabfrage, die eine Unterabfrage in der FROM-Klausel enthält
Die bereitgestellte Beispielabfrage kann nicht ohne die Verwendung einer Unterabfrage in der FROM-Klausel ausgedrückt werden. Die Unterabfrage ist erforderlich, da sie die Anzahl der vom Benutzer gesendeten Nachrichten zählen und danach filtern muss, ob die Anzahl größer als 3 ist. In diesem Fall sind Workarounds wie materialisierte Ansichten oder temporäre Tabellen erforderlich.
Das obige ist der detaillierte Inhalt vonKönnen MySQL-Ansichten Unterabfragen in der FROM-Klausel vor Version 8.0 verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!