Rumah >pangkalan data >tutorial mysql >Bagaimana untuk menggunakan kata kunci mysql yang mempunyai
Dalam mysql, kata kunci yang mempunyai perlu digunakan bersama-sama dengan pernyataan SELECT untuk menapis data terkumpul Sintaks ialah "PILIH {*|nama lajur medan} DARI nama jadual data MEMPUNYAI syarat pertanyaan;".
Persekitaran pengendalian tutorial ini: sistem windows7, versi mysql8, komputer Dell G3.
Dalam MySQL, anda boleh menggunakan kata kunci HAVING untuk menapis data terkumpul.
Format sintaks untuk menggunakan kata kunci HAVING adalah seperti berikut:
HAVING 查询条件;
Kedua-dua kata kunci HAVING dan kata kunci WHERE boleh digunakan untuk menapis data dan HAVING menyokong semua pengendali dan pengendali dalam tatabahasa kata kunci WHERE.
Tetapi kata kunci WHERE dan HAVING juga mempunyai perbezaan berikut:
Secara amnya, WHERE digunakan untuk menapis baris data, manakala HAVING digunakan untuk menapis kumpulan.
DIMANA keadaan pertanyaan tidak boleh menggunakan fungsi agregat, tetapi MEMPUNYAI syarat pertanyaan boleh menggunakan fungsi agregat.
WHERE penapis sebelum pengumpulan data, manakala MEMPUNYAI penapis selepas pengumpulan data.
WHERE menapis pada fail pangkalan data, sementara MEMPUNYAI penapisan pada hasil pertanyaan. Dalam erti kata lain, WHERE menapis secara langsung berdasarkan medan dalam jadual data, manakala HAVING menapis berdasarkan medan yang telah ditanya sebelum ini.
DIMANA keadaan pertanyaan tidak boleh menggunakan alias medan, tetapi MEMPUNYAI syarat pertanyaan boleh menggunakan alias medan.
Contoh berikut akan memberi anda pemahaman yang lebih intuitif tentang persamaan dan perbezaan antara kata kunci WHERE dan HAVING.
Contoh 1
Gunakan kata kunci HAVING dan WHERE masing-masing untuk menanyakan nama, jantina dan ketinggian pelajar yang ketinggiannya melebihi 150 dalam jadual tb_students_info. Pernyataan SQL dan hasil yang dijalankan adalah seperti berikut.
mysql> SELECT name,sex,height FROM tb_students_info -> HAVING height>150; +--------+------+--------+ | name | sex | height | +--------+------+--------+ | Dany | 男 | 160 | | Green | 男 | 158 | | Henry | 女 | 185 | | Jane | 男 | 162 | | Jim | 女 | 175 | | John | 女 | 172 | | Lily | 男 | 165 | | Susan | 男 | 170 | | Thomas | 女 | 178 | | Tom | 女 | 165 | +--------+------+--------+ 10 rows in set (0.00 sec) mysql> SELECT name,sex,height FROM tb_students_info -> WHERE height>150; +--------+------+--------+ | name | sex | height | +--------+------+--------+ | Dany | 男 | 160 | | Green | 男 | 158 | | Henry | 女 | 185 | | Jane | 男 | 162 | | Jim | 女 | 175 | | John | 女 | 172 | | Lily | 男 | 165 | | Susan | 男 | 170 | | Thomas | 女 | 178 | | Tom | 女 | 165 | +--------+------+--------+ 10 rows in set (0.00 sec)
Dalam contoh di atas, kerana medan ketinggian telah disoal selepas kata kunci PILIH, kedua-dua HAVING dan WHERE boleh digunakan. Walau bagaimanapun, jika medan ketinggian tidak ditanya selepas kata kunci SELECT, MySQL akan melaporkan ralat.
Contoh 2
Gunakan kata kunci HAVING dan WHERE untuk menanyakan nama dan jantina pelajar yang ketinggiannya melebihi 150 dalam jadual tb_students_info (berbanding Contoh 1, kali ini tiada Query medan ketinggian). Pernyataan SQL dan hasil yang dijalankan adalah seperti berikut.
mysql> SELECT name,sex FROM tb_students_info -> WHERE height>150; +--------+------+ | name | sex | +--------+------+ | Dany | 男 | | Green | 男 | | Henry | 女 | | Jane | 男 | | Jim | 女 | | John | 女 | | Lily | 男 | | Susan | 男 | | Thomas | 女 | | Tom | 女 | +--------+------+ 10 rows in set (0.00 sec) mysql> SELECT name,sex FROM tb_students_info HAVING height>150; ERROR 1054 (42S22): Unknown column 'height' in 'having clause'
Seperti yang dapat dilihat daripada keputusan, jika medan ketinggian yang digunakan dalam keadaan pertanyaan HAVING tidak ditanya selepas kata kunci PILIH, MySQL akan menggesa mesej ralat: Lajur "tinggi" dalam " having clause" is unknown ”.
Contoh 3
Kumpulkan data dalam jadual tb_students_info mengikut medan ketinggian dan gunakan kata kunci HAVING dan WHERE untuk bertanya sama ada ketinggian purata selepas kumpulan adalah lebih daripada 170 Nama pelajar, jantina dan ketinggian Penyataan SQL dan hasil larian adalah seperti berikut. Ia boleh dilihat daripada keputusan bahawa jika fungsi agregat digunakan dalam keadaan pertanyaan WHERE, MySQL akan meminta. mesej ralat: Penggunaan fungsi kumpulan tidak sah
mysql> SELECT GROUP_CONCAT(name),sex,height FROM tb_students_info -> GROUP BY height -> HAVING AVG(height)>170; +--------------------+------+--------+ | GROUP_CONCAT(name) | sex | height | +--------------------+------+--------+ | John | 女 | 172 | | Jim | 女 | 175 | | Thomas | 女 | 178 | | Henry | 女 | 185 | +--------------------+------+--------+ 4 rows in set (0.00 sec) mysql> SELECT GROUP_CONCAT(name),sex,height FROM tb_students_info WHERE AVG(height)>170 GROUP BY height; ERROR 1111 (HY000): Invalid use of group function[Cadangan berkaitan:
tutorial video mysql
]Atas ialah kandungan terperinci Bagaimana untuk menggunakan kata kunci mysql yang mempunyai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!