Rumah pangkalan data tutorial mysql Bagaimanakah Saya Boleh Menggabungkan Dua Penyata PILIH ke dalam Satu Pertanyaan Tunggal untuk Menunjukkan Kiraan Tugasan dan Kiraan Tugasan Lewat?

Bagaimanakah Saya Boleh Menggabungkan Dua Penyata PILIH ke dalam Satu Pertanyaan Tunggal untuk Menunjukkan Kiraan Tugasan dan Kiraan Tugasan Lewat?

Jan 08, 2025 pm 10:46 PM

How Can I Combine Two SELECT Statements into a Single Query to Show Task Counts and Late Task Counts?

Gabungkan hasil pernyataan SELECT ke dalam satu pertanyaan

Apabila bekerja dengan pangkalan data, adalah sangat berharga untuk menggabungkan data daripada pelbagai sumber data untuk analisis. Walau bagaimanapun, mencapai ini kadangkala memberikan cabaran. Dalam contoh ini, kami mempunyai dua pernyataan SELECT yang berasingan, setiap satu mendapatkan maklumat khusus daripada pangkalan data tugas.

Pernyataan SELECT pertama mengira bilangan tugasan yang diberikan kepada setiap orang:

SELECT ks, COUNT(*) AS '# Tasks'
FROM Table
GROUP BY ks

Pernyataan SELECT kedua mengenal pasti bilangan tugas tertunggak untuk setiap orang (tugas yang Umurnya melebihi Palt):

SELECT ks, COUNT(*) AS '# Late'
FROM Table
WHERE Age > Palt
GROUP BY ks

Matlamat kami adalah untuk menggabungkan hasil dua pertanyaan ini ke dalam jadual yang mengandungi pengecam setiap orang (ks), jumlah tugasan yang mereka ada (# Tugasan) dan bilangan tugas tertunggak yang mereka ada (# Lewat) lajur.

Satu cara untuk mencapai matlamat ini ialah menggunakan operasi JOIN. Khususnya, LEFT JOIN membolehkan kami memasukkan semua baris daripada jadual pertama (t1) dan baris yang sepadan daripada jadual kedua (t2) apabila kekunci gabungan (ks) sepadan. Jika tiada baris yang sepadan dalam t2, hasilnya akan mengandungi nilai NULL. Ini memastikan bahawa walaupun orang yang tiada tugas tertunggak akan muncul dalam keputusan akhir.

Pertanyaan berikut melaksanakan LEFT JOIN:

SELECT t1.ks, t1.[# Tasks], COALESCE(t2.[# Late], 0) AS [# Late]
FROM 
    (SELECT ks, COUNT(*) AS '# Tasks' FROM Table GROUP BY ks) t1
LEFT JOIN
    (SELECT ks, COUNT(*) AS '# Late' FROM Table WHERE Age > Palt GROUP BY ks) t2
ON (t1.ks = t2.ks);

Fungsi COALESCE mengendalikan potensi nilai NULL dalam [# Lewat], memastikan nilai 0 dikembalikan. Ini akan menghasilkan jadual output yang diingini:

<code>KS        # Tasks   # Late
person1   7         1
person2   3         1
person3   2         0  </code>

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggabungkan Dua Penyata PILIH ke dalam Satu Pertanyaan Tunggal untuk Menunjukkan Kiraan Tugasan dan Kiraan Tugasan Lewat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Bagaimana cara memformat tarikh di MySQL? Bagaimana cara memformat tarikh di MySQL? Sep 19, 2025 am 02:06 AM

Fungsi date_format () MySQL digunakan untuk menyesuaikan format paparan tarikh dan masa. Sintaks adalah date_format (tarikh, format), dan menyokong pelbagai format aksara seperti %y, %m, %d, dan lain -lain, yang dapat merealisasikan paparan tarikh, statistik kumpulan dan fungsi lain.

Bagaimana menggunakan pernyataan kes di MySQL? Bagaimana menggunakan pernyataan kes di MySQL? Sep 20, 2025 am 02:00 AM

Jawapannya ialah: Kenyataan kes MySQL digunakan untuk melaksanakan logik bersyarat dalam pertanyaan, dan menyokong dua bentuk: mudah dan carian. Nilai -nilai yang berbeza boleh dikembalikan secara dinamik dalam klausa seperti Select, Where, and Orderby; Sebagai contoh, dalam Pilihan, klasifikasi skor oleh segmen pecahan, menggabungkan fungsi agregat untuk mengira bilangan negeri, atau mengutamakan peranan tertentu dalam urutan, adalah perlu untuk sentiasa berakhir dengan akhir dan disyorkan untuk menggunakan yang lain untuk mengendalikan situasi lalai.

Bagaimana cara mengautomasikan sandaran MySQL dengan skrip? Bagaimana cara mengautomasikan sandaran MySQL dengan skrip? Sep 21, 2025 am 02:24 AM

Buat skrip shell yang mengandungi konfigurasi pangkalan data dan perintah mysqldump dan simpannya sebagai mysql_backup.sh; 2. Simpan kelayakan MySQL dengan membuat fail ~/.my.cnf dan tetapkan 600 kebenaran untuk meningkatkan keselamatan, mengubah suai skrip untuk menggunakan pengesahan fail konfigurasi; 3. Gunakan Chmod X untuk membuat skrip boleh dilaksanakan dan menguji secara manual sama ada sandaran berjaya; 4. Tambah tugas berjadual melalui Crontab-E, seperti 02/Path/to/mysql_backup.sh >>/path/to/sandaran/sandaran.log2> & 1, merealisasikan sandaran automatik dan pembalakan pada pukul 2 pagi setiap hari; 5.

Bagaimana cara menggunakan auto_increment di mysql? Bagaimana cara menggunakan auto_increment di mysql? Sep 16, 2025 am 07:41 AM

AUTO_INCREMENT Secara automatik menjana nilai unik untuk lajur utama utama jadual MySQL. Apabila membuat jadual, tentukan atribut ini dan pastikan lajur diindeks. Apabila memasukkan data, isi lajur atau tetapkannya ke Null untuk mencetuskan tugasan automatik. ID yang paling baru -baru ini boleh diperolehi melalui fungsi last_insert_id (). Nilai permulaan dan saiz langkah boleh disesuaikan melalui pembolehubah altertable atau sistem, yang sesuai untuk pengurusan pengenalan yang unik.

Cara mengemas kini baris jika ada atau masukkan jika tidak di mysql Cara mengemas kini baris jika ada atau masukkan jika tidak di mysql Sep 21, 2025 am 01:45 AM

Masukkan ... Pelaksanaan OnDupliceKeyUpdate akan dikemas kini jika ia wujud, jika tidak, ia akan dimasukkan, dan ia memerlukan kekangan utama yang unik atau utama; 2. 3. Insertignore hanya memasukkan dan tidak berulang data, dan tidak mengemaskini. Adalah disyorkan untuk menggunakan pelaksanaan pertama UPSERT.

Bagaimana untuk memilih nilai yang berbeza dalam MySQL? Bagaimana untuk memilih nilai yang berbeza dalam MySQL? Sep 16, 2025 am 12:52 AM

Gunakan kata kunci yang berbeza untuk mengalih keluar nilai pendua dari lajur yang ditentukan dan mengembalikan nilai unik. 1. Sintaks asas adalah selectdistinctcolumn_namefromtable_name; 2. Permintaan nilai unik satu lajur, seperti selectDistinctCityFromCustomers; 3. Permintaan gabungan unik pelbagai lajur, seperti selectDistinctCity, statefromCustomers; 4. Penapis dengan klausa WHERE dan dapatkan nilai yang unik, seperti selectDistinctProduct_Namefromorderswherordorder_date> '202

Bagaimana cara menggunakan subqueries di MySQL? Bagaimana cara menggunakan subqueries di MySQL? Sep 20, 2025 am 01:07 AM

Subqueries boleh digunakan di mana, dari, pilih, dan mempunyai klausa untuk melaksanakan penapisan atau pengiraan berdasarkan hasil pertanyaan lain. Pengendali seperti dalam, mana -mana, semuanya biasa digunakan di mana; alias diperlukan sebagai jadual derivatif dari; Nilai tunggal mesti dikembalikan dalam SELECT; Subqueries yang berkaitan bergantung pada pertanyaan luar untuk melaksanakan setiap baris. Sebagai contoh, periksa pekerja yang purata gaji lebih tinggi daripada jabatan, atau tambahkan senarai gaji purata syarikat. Subqueries meningkatkan kejelasan logik, tetapi prestasi mungkin lebih rendah daripada bergabung, jadi anda perlu memastikan bahawa anda mengembalikan hasil yang diharapkan.

Bagaimana cara menggunakan perintah menjelaskan di MySQL? Bagaimana cara menggunakan perintah menjelaskan di MySQL? Sep 18, 2025 am 01:48 AM

JelaskanInmysqlrevealsQueryExecutionPlans, memperlihatkanIndexusage, tableadorder, androwfilteringtooptimizeperformance; ussitbeforeselecttoanalyzesteps, checkkeycolumnsliketypeandrows, identiffiCienciesinextra, danctombinewithindexingstrategiestrategiestrategiestrategiestrategiestrategiestrategiestrategiestrategiestrategiestrategiestrategiestrategi

See all articles