Bagaimana untuk menggunakan kata kunci mysql yang mempunyai

青灯夜游
Lepaskan: 2022-02-24 19:06:05
asal
15919 orang telah melayarinya

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;".

Bagaimana untuk menggunakan kata kunci mysql yang mempunyai

Persekitaran pengendalian tutorial ini: sistem windows7, versi mysql8, komputer Dell G3.

MYSQL HAVING: Pengumpulan penapis

Dalam MySQL, anda boleh menggunakan kata kunci HAVING untuk menapis data terkumpul.

Format sintaks untuk menggunakan kata kunci HAVING adalah seperti berikut:

HAVING 查询条件;
Salin selepas log masuk

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)
Salin selepas log masuk

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'
Salin selepas log masuk

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
Salin selepas log masuk
[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!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!