cari
Rumahpangkalan dataSQLsql执行顺序是什么

sql执行顺序是什么

Jun 10, 2019 am 10:36 AM

sql执行顺序是什么

SQL语句的执行顺序

MySQL的语句一共分为11步,如下图所标注的那样,最先执行的总是FROM操作,最后执行的是LIMIT操作。其中每一个操作都会产生一张虚拟的表,这个虚拟的表作为一个处理的输入,只是这些虚拟的表对用户来说是透明的,但是只有最后一个虚拟的表才会被作为结果返回。如果没有在语句中指定某一个子句,那么将会跳过相应的步骤。

下面我们来具体分析一下查询处理的每一个阶段

FORM: 对FROM的左边的表和右边的表计算笛卡尔积。产生虚表VT1

ON: 对虚表VT1进行ON筛选,只有那些符合的行才会被记录在虚表VT2中。

JOIN: 如果指定了OUTER JOIN(比如left join、 right join),那么保留表中未匹配的行就会作为外部行添加到虚拟表VT2中,产生虚拟表VT3, rug from子句中包含两个以上的表的话,那么就会对上一个join连接产生的结果VT3和下一个表重复执行步骤1~3这三个步骤,一直到处理完所有的表为止

WHERE: 对虚拟表VT3进行WHERE条件过滤。只有符合的记录才会被插入到虚拟表VT4中。

GROUP BY: 根据group by子句中的列,对VT4中的记录进行分组操作,产生VT5.

CUBE | ROLLUP: 对表VT5进行cube或者rollup操作,产生表VT6.

HAVING: 对虚拟表VT6应用having过滤,只有符合的记录才会被 插入到虚拟表VT7中。

SELECT: 执行select操作,选择指定的列,插入到虚拟表VT8中。

DISTINCT: 对VT8中的记录进行去重。产生虚拟表VT9.

ORDER BY: 将虚拟表VT9中的记录按照进行排序操作,产生虚拟表VT10.

LIMIT:取出指定行的记录,产生虚拟表VT11, 并将结果返回。

写的顺序:select ... from... where.... group by... having... order by.. limit [offset,] 

(rows)

执行顺序:from... where...group by... having.... select ... order by... limit

Atas ialah kandungan terperinci sql执行顺序是什么. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
SQL: Keluk Pembelajaran untuk PemulaSQL: Keluk Pembelajaran untuk PemulaApr 16, 2025 am 12:11 AM

Kurva pembelajaran SQL adalah curam, tetapi ia dapat dikuasai melalui amalan dan memahami konsep teras. 1. Operasi asas termasuk pilih, masukkan, kemas kini, padam. 2. Pelaksanaan pertanyaan dibahagikan kepada tiga langkah: analisis, pengoptimuman dan pelaksanaan. 3. Penggunaan asas adalah seperti menanyakan maklumat pekerja, dan penggunaan lanjutan adalah seperti menggunakan Jadual Sambungan Join. 4. Kesilapan umum termasuk tidak menggunakan suntikan alias dan SQL, dan pertanyaan parameter diperlukan untuk mencegahnya. 5. Pengoptimuman prestasi dicapai dengan memilih lajur yang diperlukan dan mengekalkan pembacaan kod.

SQL: Perintah, MySQL: EnjinSQL: Perintah, MySQL: EnjinApr 15, 2025 am 12:04 AM

Perintah SQL dibahagikan kepada lima kategori dalam MySQL: DQL, DDL, DML, DCL dan TCL, dan digunakan untuk menentukan, mengendalikan dan mengawal data pangkalan data. MySQL memproses arahan SQL melalui analisis leksikal, analisis sintaks, pengoptimuman dan pelaksanaan, dan menggunakan pengoptimuman indeks dan pertanyaan untuk meningkatkan prestasi. Contoh penggunaan termasuk pilih untuk pertanyaan data dan bergabung dengan operasi multi-meja. Kesalahan umum termasuk isu sintaks, logik, dan prestasi, dan strategi pengoptimuman termasuk menggunakan indeks, mengoptimumkan pertanyaan, dan memilih enjin penyimpanan yang betul.

SQL untuk Analisis Data: Teknik Lanjutan untuk Perniagaan PerniagaanSQL untuk Analisis Data: Teknik Lanjutan untuk Perniagaan PerniagaanApr 14, 2025 am 12:02 AM

Kemahiran pertanyaan lanjutan di SQL termasuk subqueries, fungsi tetingkap, CTE dan gabungan kompleks, yang dapat mengendalikan keperluan analisis data yang kompleks. 1) Subquery digunakan untuk mencari pekerja dengan gaji tertinggi di setiap jabatan. 2) Fungsi tetingkap dan CTE digunakan untuk menganalisis trend pertumbuhan gaji pekerja. 3) Strategi Pengoptimuman Prestasi termasuk pengoptimuman indeks, penulisan semula pertanyaan dan menggunakan jadual partition.

MySQL: Pelaksanaan khusus SQLMySQL: Pelaksanaan khusus SQLApr 13, 2025 am 12:02 AM

MySQL adalah sistem pengurusan pangkalan data sumber terbuka yang menyediakan fungsi dan sambungan SQL standard. 1) MySQL menyokong operasi SQL standard seperti membuat, memasukkan, mengemas kini, memadam, dan melanjutkan klausa had. 2) Ia menggunakan enjin penyimpanan seperti InnoDB dan Myisam, yang sesuai untuk senario yang berbeza. 3) Pengguna boleh menggunakan MySQL dengan cekap melalui fungsi lanjutan seperti membuat jadual, memasukkan data, dan menggunakan prosedur yang disimpan.

SQL: Membuat pengurusan data boleh diakses oleh semuaSQL: Membuat pengurusan data boleh diakses oleh semuaApr 12, 2025 am 12:14 AM

SqlmakesdatamanagementaccessibleLyprovidingasimpleyetPowultoLsetForqueryingandManagingDataBases.1) itworksWithRelationalDataBases, membolehkanSengserSteShipifyWheyTheyWantTodoThedata.2)

Strategi Pengindeksan SQL: Meningkatkan prestasi pertanyaan dengan pesanan magnitudStrategi Pengindeksan SQL: Meningkatkan prestasi pertanyaan dengan pesanan magnitudApr 11, 2025 am 12:04 AM

Indeks SQL dapat meningkatkan prestasi pertanyaan melalui reka bentuk pintar. 1. Pilih jenis indeks yang sesuai, seperti B-Tree, Hash atau Indeks Teks Penuh. 2. Gunakan indeks komposit untuk mengoptimumkan pertanyaan berbilang bidang. 3. Elakkan daripada indeks untuk mengurangkan overhead penyelenggaraan data. 4. Mengekalkan indeks secara teratur, termasuk membina semula dan mengeluarkan indeks yang tidak perlu.

Cara memadam kekangan dalam SQLCara memadam kekangan dalam SQLApr 10, 2025 pm 12:21 PM

Untuk memadam kekangan dalam SQL, lakukan langkah -langkah berikut: Kenal pasti nama kekangan yang akan dipadam; Gunakan Penyata Jadual ALTER: Alter jadual Jadual Nama Kekangan Kekangan Nama Kekangan; Sahkan penghapusan.

Cara menetapkan pencetus sqlCara menetapkan pencetus sqlApr 10, 2025 pm 12:18 PM

Pencetus SQL adalah objek pangkalan data yang secara automatik melakukan tindakan tertentu apabila peristiwa tertentu dilaksanakan pada jadual yang ditentukan. Untuk menyediakan pencetus SQL, anda boleh menggunakan pernyataan pencetus CREATE, yang termasuk nama pencetus, nama jadual, jenis acara, dan kod pencetus. Kod pencetus ditakrifkan menggunakan kata kunci AS dan mengandungi pernyataan SQL atau PL/SQL atau blok. Dengan menentukan keadaan pencetus, anda boleh menggunakan klausa WHERE untuk mengehadkan skop pelaksanaan pencetus. Operasi pencetus boleh dilakukan dalam kod pencetus menggunakan penyata masuk, kemas kini, atau padam. Kata kunci baru dan lama boleh digunakan untuk merujuk kata kunci yang terjejas dalam kod pencetus.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),