cari
Rumahpangkalan datatutorial mysqlPenjelasan terperinci tentang kaedah pembukaan sebenar Kumpulan MySql mengikut fungsi!

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)

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>

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

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

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
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

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!

Kenyataan
Artikel ini dikembalikan pada:segmentfault. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
带你搞懂Java结构化数据处理开源库SPL带你搞懂Java结构化数据处理开源库SPLMay 24, 2022 pm 01:34 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

Java集合框架之PriorityQueue优先级队列Java集合框架之PriorityQueue优先级队列Jun 09, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

完全掌握Java锁(图文解析)完全掌握Java锁(图文解析)Jun 14, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

一起聊聊Java多线程之线程安全问题一起聊聊Java多线程之线程安全问题Apr 21, 2022 pm 06:17 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

Java基础归纳之枚举Java基础归纳之枚举May 26, 2022 am 11:50 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

详细解析Java的this和super关键字详细解析Java的this和super关键字Apr 30, 2022 am 09:00 AM

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

Java数据结构之AVL树详解Java数据结构之AVL树详解Jun 01, 2022 am 11:39 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于平衡二叉树(AVL树)的相关知识,AVL树本质上是带了平衡功能的二叉查找树,下面一起来看一下,希望对大家有帮助。

一文掌握Java8新特性Stream流的概念和使用一文掌握Java8新特性Stream流的概念和使用Jun 23, 2022 pm 12:03 PM

本篇文章给大家带来了关于Java的相关知识,其中主要整理了Stream流的概念和使用的相关问题,包括了Stream流的概念、Stream流的获取、Stream流的常用方法等等内容,下面一起来看一下,希望对大家有帮助。

See all articles

Alat AI Hot

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.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa