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!