在SQL中,“Case When”语句用于选择判断,在执行时先对条件进行判断,然后根据判断结果做出相应的操作;语法“CASE 字段 WHEN 条件1 THEN 操作1 WHEN 条件2 THEN 操作2...ELSE 操作n END;”。
本教程操作环境:windows7系统、Microsoft SQL Server 2016版、Dell G3电脑。
SQL中case when的用法
case when类似于编程语言中的if else判断、switch case语句。该语句执行时先对条件进行判断,然后根据判断结果做出相应的操作。
Case具有两种格式:简单Case函数和Case搜索函数。
简单Case函数:
CASE sex WHEN ‘1’ THEN ‘男’ WHEN ‘0’ THEN ‘女’ ELSE ‘其他’ END
Case搜索函数:
CASE WHEN sex = ‘1’ THEN ‘男’ WHEN sex = ‘0’ THEN ‘女’ ELSE ‘其他’ END
显然,简单Case函数胜在简洁,但是它只适用于这种单字段的单值比较,而Case搜索函数的优点在于适用于所有比较的情况。
还有一个需要注意的问题,Case函数在满足了某个符合条件后,剩下的条件将会被自动忽略,因此,即使满足多个条件,执行过程中也只认第一个条件。
(PHP中文网,有大量免费的SQL教程,欢迎大家学习!)
在使用 CASE WHEN时,可以把它当作一个逻辑上的匿名字段,字段值根据条件确认,在需要使用字段名时可以是用 as来定义别名。这么说还很抽象,看看下面 CASE WHEN的使用案例就清楚了。
使用场景
1、可以将已知数据按照某种方式进行分组,分析。
根据这个国家人口数据,统计亚洲和北美洲的人口数量。使用如下 SQL:
SELECT CASE country WHEN '中国' THEN '亚洲' WHEN '印度' THEN '亚洲' WHEN '日本' THEN '亚洲' WHEN '美国' THEN '北美洲' WHEN '加拿大' THEN '北美洲' WHEN '墨西哥' THEN '北美洲' ELSE '其他' END as '洲' , SUM(population) as '人口' FROM test GROUP BY CASE country WHEN '中国' THEN '亚洲' WHEN '印度' THEN '亚洲' WHEN '日本' THEN '亚洲' WHEN '美国' THEN '北美洲' WHEN '加拿大' THEN '北美洲' WHEN '墨西哥' THEN '北美洲' ELSE '其他' END;
这里的两个CASE WHEN都相当于一个字段,不过值得一提的是,第二个CASE WHEN 的THEN值并不用写明是什么洲,它只是用于将记录进行分组,所以THEN后面的值只有能区分这三种记录就行,GROUP BY也可以写成:
GROUP BY CASE country WHEN '中国' THEN 0 WHEN '印度' THEN 0 WHEN '日本' THEN 0 WHEN '美国' THEN 1 WHEN '加拿大' THEN 1 WHEN '墨西哥' THEN 1 ELSE 2 END;
2、用一个SQL语句完成不同条件的分组。
有如下数据:
用Case函数来完成按照国家和性别进行分组。使用如下SQL:
SELECT country, SUM( CASE WHEN sex = '1' THEN population ELSE 0 END ), --男性人口 SUM( CASE WHEN sex = '2' THEN population ELSE 0 END ) --女性人口 FROM Table_A GROUP BY country;
得到如下结果:
就第一个CASE WHEN讲解:
CASE WHEN sex = '1' THEN population ELSE 0 END
当记录的sex为1时,这个字段的值为记录的population值,否则为0,因此能计算出一个国家的男性人口。
更多SQL等编程入门教程,请持续关注PHP中文网!!
Atas ialah kandungan terperinci SQL中Case When的用法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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.

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.

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.

Pengindeksan adalah struktur data yang mempercepat carian data dengan menyusun lajur data. Langkah -langkah untuk menambah indeks ke pertanyaan SQL adalah seperti berikut: Tentukan lajur yang perlu diindeks. Pilih jenis indeks yang sesuai (B-Tree, Hash, atau Bitmap). Gunakan arahan Buat Indeks untuk membuat indeks. Membina semula atau menyusun semula indeks secara teratur untuk mengekalkan kecekapannya. Manfaat penambahan indeks termasuk prestasi pertanyaan yang lebih baik, mengurangkan operasi I/O, penyortiran dan penapisan yang dioptimumkan, dan peningkatan kesesuaian. Apabila pertanyaan sering menggunakan lajur tertentu, pulangkan sejumlah besar data yang perlu disusun atau dikelompokkan, melibatkan pelbagai jadual atau jadual pangkalan data yang besar, anda harus mempertimbangkan untuk menambah indeks.

Kenyataan IFELSE adalah pernyataan bersyarat yang mengembalikan nilai yang berbeza berdasarkan hasil penilaian bersyarat. Struktur sintaksinya ialah: jika (keadaan) kemudian return_value_if_condition_is_true else return_value_if_condition_is_false end if;.

Kaedah untuk melihat ralat pangkalan data SQL adalah: 1. Lihat mesej ralat secara langsung; 2. Gunakan kesilapan menunjukkan dan menunjukkan perintah amaran; 3. Akses log ralat; 4. Gunakan kod ralat untuk mencari punca kesilapan; 5. Semak sambungan pangkalan data dan sintaks pertanyaan; 6. Gunakan alat debugging.

Pengendali yang berbeza digunakan untuk mengecualikan baris pendua dalam pertanyaan SQL dan mengembalikan nilai unik sahaja. Ia sesuai untuk senario seperti mendapatkan senarai nilai unik, mengira bilangan nilai unik, dan menggunakannya dalam kombinasi dengan kumpulan oleh.

Kaedah untuk menetapkan kekunci calon dalam SQL: Tentukan lajur pengenalan yang unik; Buat kunci utama menggunakan kekangan utama utama; Tambah kekangan yang unik menggunakan kekangan yang unik; Buat indeks unik. Menetapkan kekunci calon memastikan integriti data, meningkatkan prestasi pertanyaan, dan menghalang pertindihan data.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

Dreamweaver CS6
Alat pembangunan web visual

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod