So verwenden Sie as in einer SQL-Anweisung
WITH AS-Phrase, auch Unterabfrageteil genannt, kann ein SQL-Fragment definieren, das von der gesamten SQL-Anweisung verwendet wird. Es kann die SQL-Anweisung besser lesbar machen oder als Teil verwendet werden, der Daten in verschiedenen Teilen von UNION ALL bereitstellt.
– für einen Alias
with tmp as (select * from tb_name)
– für mehrere Aliase
with tmp as (select * from tb_name), tmp2 as (select * from tb_name2), tmp3 as (select * from tb_name3), …
– entspricht dem Erstellen einer temporären E-Tabelle
with e as (select * from scott.emp e where e.empno=7499) select * from e;
– entspricht dem Erstellen einer temporären E- und D-Tabelle
with e as (select * from scott.emp), d as (select * from scott.dept) select * from e, d where e.deptno = d.deptno;
ist eigentlich eine große SQL-Anweisung Werden vom Heap wiederholt verwendet, werden sie mit as abgelegt und ein Alias angegeben, damit nachfolgende Abfragen ihn verwenden können. Dies spielt eine Optimierungsrolle bei großen SQL-Anweisungsstapeln und ist klar.
Mit der Verwendung zum Einfügen von Daten in eine Tabelle
insert into table2 with s1 as (select rownum c1 from dual connect by rownum <= 10), s2 as (select rownum c2 from dual connect by rownum <= 10) select a.c1, b.c2 from s1 a, s2 b where…;
wählen Sie s1.sid, s2.sid aus s1, s2 muss zugehörige Bedingungen haben, andernfalls ist das Ergebnis ein kartesisches Produkt.
mit als Äquivalent zur virtuellen Ansicht.
Mit einer Phrase, auch Unterabfrage-Factoring genannt, können Sie viele Dinge tun, beispielsweise ein SQL-Fragment definieren, das von der gesamten SQL-Anweisung verwendet wird. Manchmal dient es dazu, die SQL-Anweisung besser lesbar zu machen, oder sie befindet sich möglicherweise in verschiedenen Teilen der Union und ist der Teil, der Daten bereitstellt.
Besonders nützlich für alle. Da jeder Teil der Vereinigung gleich sein kann, aber wenn jeder Teil einmal ausgeführt wird, sind die Kosten zu hoch, sodass Sie „with“ als Phrase verwenden können, die nur einmal ausgeführt werden muss. Wenn der durch die with as-Phrase definierte Tabellenname mehr als zweimal aufgerufen wird, fügt der Optimierer die durch die with as-Phrase erhaltenen Daten automatisch in eine temporäre Tabelle ein. Wenn er nur einmal aufgerufen wird, wird dies nicht der Fall sein. Die Eingabeaufforderung materialize erzwingt, dass die Daten in der with as Phrase in eine globale temporäre Tabelle eingefügt werden. Viele Abfragen können auf diese Weise beschleunigt werden.
with sql1 as (select to_char(a) s_name from test_tempa), sql2 as (select to_char(b) s_name from test_tempb where not exists (select s_name from sql1 where rownum=1)) select * from sql1 union all select * from sql2 union all select ‘no records’ from dual where not exists (select s_name from sql1 where rownum=1) and not exists (select s_name from sql2 where rownum=1);
Vorteile der WITH-Anweisung:
(1) Die SQL-Lesbarkeit wird verbessert. Geben Sie beispielsweise einer bestimmten Unterabfrage usw. einen aussagekräftigen Namen.
(2) Die with-Unterabfrage wird nur einmal ausgeführt und die Ergebnisse werden im temporären Tabellenbereich des Benutzers gespeichert, auf den zur Verbesserung der Leistung mehrmals verwiesen werden kann.
Beispiel: Während des Excel-Importvorgangs müssen die Daten manchmal in einer temporären Tabelle gespeichert werden. Beim nächsten Import werden die Daten in der temporären Tabelle jedoch manchmal gelöscht Es kann vorkommen, dass zwei Benutzer die Daten des anderen separat verarbeiten, was zu Verwirrung führen kann. Sie können jedoch die WITH-Funktion und die UNION-Anweisung verwenden, um eine SQL-Anweisung zu verbinden und in SESSION zu speichern Diese Anweisung dient zum Erstellen von Daten.
Verwandte Empfehlungen: „MySQL-Tutorial“
Das obige ist der detaillierte Inhalt vonSo verwenden Sie as in einer SQL-Anweisung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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



HQL und SQL werden im Hibernate-Framework verglichen: HQL (1. Objektorientierte Syntax, 2. Datenbankunabhängige Abfragen, 3. Typsicherheit), während SQL die Datenbank direkt betreibt (1. Datenbankunabhängige Standards, 2. Komplexe ausführbare Datei). Abfragen und Datenmanipulation).

„Verwendung der Divisionsoperation in OracleSQL“ In OracleSQL ist die Divisionsoperation eine der häufigsten mathematischen Operationen. Während der Datenabfrage und -verarbeitung können uns Divisionsoperationen dabei helfen, das Verhältnis zwischen Feldern zu berechnen oder die logische Beziehung zwischen bestimmten Werten abzuleiten. In diesem Artikel wird die Verwendung der Divisionsoperation in OracleSQL vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Zwei Arten von Divisionsoperationen in OracleSQL In OracleSQL können Divisionsoperationen auf zwei verschiedene Arten durchgeführt werden.

Oracle und DB2 sind zwei häufig verwendete relationale Datenbankverwaltungssysteme, die jeweils über ihre eigene, einzigartige SQL-Syntax und -Eigenschaften verfügen. In diesem Artikel werden die SQL-Syntax von Oracle und DB2 verglichen und unterschieden und spezifische Codebeispiele bereitgestellt. Datenbankverbindung Verwenden Sie in Oracle die folgende Anweisung, um eine Verbindung zur Datenbank herzustellen: CONNECTusername/password@database. In DB2 lautet die Anweisung zum Herstellen einer Verbindung zur Datenbank wie folgt: CONNECTTOdataba

Interpretation der dynamischen SQL-Tags von MyBatis: Detaillierte Erläuterung der Verwendung von Set-Tags. MyBatis ist ein hervorragendes Persistenzschicht-Framework. Es bietet eine Fülle dynamischer SQL-Tags und kann Datenbankoperationsanweisungen flexibel erstellen. Unter anderem wird das Set-Tag zum Generieren der SET-Klausel in der UPDATE-Anweisung verwendet, die sehr häufig bei Aktualisierungsvorgängen verwendet wird. In diesem Artikel wird die Verwendung des Set-Tags in MyBatis ausführlich erläutert und seine Funktionalität anhand spezifischer Codebeispiele demonstriert. Was ist Set-Tag? Set-Tag wird in MyBati verwendet

Was ist Identität in SQL? In SQL ist Identität ein spezieller Datentyp, der zum Generieren automatisch inkrementierender Zahlen verwendet wird. Er wird häufig verwendet, um jede Datenzeile in einer Tabelle eindeutig zu identifizieren. Die Spalte „Identität“ wird oft in Verbindung mit der Primärschlüsselspalte verwendet, um sicherzustellen, dass jeder Datensatz eine eindeutige Kennung hat. In diesem Artikel wird die Verwendung von Identity detailliert beschrieben und es werden einige praktische Codebeispiele aufgeführt. Die grundlegende Möglichkeit, Identity zu verwenden, besteht darin, Identit beim Erstellen einer Tabelle zu verwenden.

Hintergrund: Eine der Anforderungen des Unternehmens besteht darin, dass die vorhandene Link-Tracking-Protokollkomponente das Drucken der SQL-Ausführungszeit von MySQL unterstützen muss. Die übliche Methode zur Implementierung der Link-Tracking besteht darin, die von einem Drittanbieter-Framework oder -Tool bereitgestellte Interceptor-Schnittstelle oder Filterschnittstelle zu implementieren. MySQL ist keine Ausnahme. Tatsächlich implementiert es lediglich die von MySQL gesteuerte Interceptor-Schnittstelle. Es gibt verschiedene Versionen von Kanälen, die speziell MySQL implementieren, und die Interceptor-Schnittstellen verschiedener Versionen sind unterschiedlich. Daher müssen Sie den Antwort-Interceptor entsprechend den verschiedenen Versionen des von Ihnen verwendeten MySQL-Treibers implementieren. Als Nächstes stellen wir MySQL-Kanäle 5 vor bzw. 8 Versionsimplementierung. MySQL5 wird hier unter Verwendung der MySQL-Kanalversion 5.1.18 als Beispiel für die Implementierung von Statem implementiert

Lösung: 1. Überprüfen Sie, ob der angemeldete Benutzer über ausreichende Berechtigungen zum Zugriff auf oder zum Betrieb der Datenbank verfügt, und stellen Sie sicher, dass der Benutzer über die richtigen Berechtigungen verfügt. 2. Überprüfen Sie, ob das Konto des SQL Server-Dienstes über die Berechtigung zum Zugriff auf die angegebene Datei verfügt Ordner und stellen Sie sicher, dass das Konto über ausreichende Berechtigungen zum Lesen und Schreiben der Datei oder des Ordners verfügt. 3. Überprüfen Sie, ob die angegebene Datenbankdatei von anderen Prozessen geöffnet oder gesperrt wurde. Versuchen Sie, die Datei zu schließen oder freizugeben, und führen Sie die Abfrage erneut aus . Versuchen Sie es als Administrator. Führen Sie Management Studio aus als usw.

Wenn Springboot + Mybatis-plus keine SQL-Anweisungen zum Hinzufügen mehrerer Tabellen verwendet, werden die Probleme, auf die ich gestoßen bin, durch die Simulation des Denkens in der Testumgebung zerlegt: Erstellen Sie ein BrandDTO-Objekt mit Parametern, um die Übergabe von Parametern an den Hintergrund zu simulieren dass es äußerst schwierig ist, Multi-Table-Operationen in Mybatis-plus durchzuführen. Wenn Sie keine Tools wie Mybatis-plus-join verwenden, können Sie nur die entsprechende Mapper.xml-Datei konfigurieren und die stinkende und lange ResultMap konfigurieren Schreiben Sie die entsprechende SQL-Anweisung. Obwohl diese Methode umständlich erscheint, ist sie äußerst flexibel und ermöglicht es uns
