Rumah > pangkalan data > tutorial mysql > Penjelasan terperinci tentang kaedah pembukaan sebenar Kumpulan MySql mengikut fungsi!

Penjelasan terperinci tentang kaedah pembukaan sebenar Kumpulan MySql mengikut fungsi!

藏色散人
Lepaskan: 2022-02-09 09:07:53
ke hadapan
2586 orang telah melayarinya

Artikel ini akan memperkenalkan anda kepada cara yang betul untuk membuka Kumpulan MySql mengikut fungsi. Saya harap ia akan membantu anda!

Apabila menggunakan fungsi kumpulan untuk menapis set hasil, beberapa masalah dihadapi dan penyelesaian [Disyorkan : tutorial video mysql]

1. Senario aplikasi

Terdapat dua jadual

Jadual artikel (satu-ke-banyak mesej Jadual) t_posts:
oid, posts_name
Jadual mesej (jadual artikel banyak-ke-satu) t_comment:
oid, posts_id, msg_content, create_time

2. Analisis keperluan

Soal kandungan jawapan terkini setiap artikel

3.SQL writing

select 
  tp.oid,
  tp.posts_name,
  tc.msg_content,
  tc.create_time
from t_posts tp 
left join t_comment tc on tp.oid = tc.posts_id
group by tp.oid having create_time = max(create_time)
Salin selepas log masuk

Andaikan terdapat dua artikel A dan B (urutan rekod balasan dalam pangkalan data adalah konsisten dengan yang berikut)

<p>A有一个回复记录时间为: 2019-09-10   <br>A有一个回复记录时间为: 2019-09-11   <br>B有一个回复记录时间为: 2019-09-01   <br>B有一个回复记录时间为: 2019-09-09<br></p>
Salin selepas log masuk

Jalankan sql di atas, anda akan mendapati bahawa sejumlah besar rekod hilang dalam set hasil , dan hasilnya salah Selepas menanyakan data, kami mendapati bahawa

pemilik mysql dilaksanakan selepas kumpulan mengikut, iaitu, mengumpulkan dahulu dan kemudian menapis. , tetapi kerana terdapat lebih daripada dua rekod mesej,
Jadi hasil yang ditetapkan selepas pengumpulan hanya akan mengambil mesej pertama setiap mesej sebagai maklumat rekod selepas pengumpulan Pada masa ini, jika anda menggunakan mempunyai create_time = max(create_time)
, maka max(create_time) ialah nilai maksimum kumpulan semasa Masa

ialah: 2019-09-09

, jadi sql di atas akan kehilangan set hasil

4 Ubah suai SQL

Kerana kita tahu set hasil pendua yang digabungkan selepas pengumpulan adalah yang mempunyai rownum terkecil. , bolehkah kita mengubah suai SQL seperti berikut??

select 
  tp.oid,
  tp.posts_name,
  tc.msg_content,
  tc.create_time
from t_posts tp 
left join t_comment tc on tp.oid = tc.posts_id
group by tp.oid having create_time = max(create_time)
-- 下面的是新增的sql
order by tc.create_time desc
Salin selepas log masuk

Selepas menjalankannya, saya dapati ia masih tidak bagus, jadi, buktikan bahawa susunan mengikut adalah selepas kumpulan oleh & mempunyai

Kemudian saya memikirkannya, bolehkah saya menggunakan pesanan dengan terus untuk mengoptimumkan hasil terkumpul tanpa perlu?

mempunyai masa_cipta = maks(masa_buat)

select 
  tp.oid,
  tp.posts_name,
  tc.msg_content,
  tc.create_time
from t_posts tp 
left join t_comment tc on tp.oid = tc.posts_id
group by tp.oid 
order by tc.create_time desc
Salin selepas log masuk

Ralat set hasil tidak menjejaskan keputusan kumpulan Set hasil pendua masih digabungkan mengikut kumpulan minimum rownum, dan kemudian diisih

5 >

Oleh kerana tertib mengikut hanya boleh menjejaskan kumpulan mengikut, adakah mungkin untuk mengisih hasil yang ditetapkan sebelum kumpulan mengikut, dan kemudian mengumpulkannya?

select * from (
  select 
    tp.oid,
    tp.posts_name,
    tc.msg_content,
    tc.create_time
  from t_posts tp 
  left join t_comment tc on tp.oid = tc.posts_id
  order by tc.create_time desc
) t 
group by t.oid
Salin selepas log masuk
Saya mendapati ia masih tidak berfungsi, tetapi subkueri itu memang diisih dahulu

Selepas bertanya (terangkan), saya mendapati bahawa susunan mengikut subkueri telah dioptimumkan Penyelesaian:

    Had penggunaan 99999 dalam. subquery
  1. Gunakan di mana keadaan dalam subquery, create_time = (pilih maks(create_time) daripada kumpulan t_comment mengikut oid)
select * from (
  select 
    tp.oid,
    tp.posts_name,
    tc.msg_content,
    tc.create_time
  from t_posts tp 
  left join t_comment tc on tp.oid = tc.posts_id
  order by tc.create_time desc limit 9999
) t 
group by t.oid
Salin selepas log masuk

Selesai

Mata pengetahuan tambahan:

Perbezaan antara versi mysql5.5 dan mysql 5.7: Dalam versi 5.7, jika had tidak digunakan, kumpulan mengikut akan mengoptimumkan susunan mengikut

Atas ialah kandungan terperinci Penjelasan terperinci tentang kaedah pembukaan sebenar Kumpulan MySql mengikut fungsi!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:segmentfault.com
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