Heim > Datenbank > MySQL-Tutorial > Wie berechnet man den Prozentsatz übereinstimmender Werte in einer SQL-SELECT-Abfrage?

Wie berechnet man den Prozentsatz übereinstimmender Werte in einer SQL-SELECT-Abfrage?

Mary-Kate Olsen
Freigeben: 2024-12-27 03:49:09
Original
849 Leute haben es durchsucht

How to Calculate the Percentage of Matching Values in a SQL SELECT Query?

Prozentsätze aus SUM() in derselben SELECT-Abfrage berechnen

In der Tabelle my_obj, in der die Ganzzahlfelder value_a und value_b vorhanden sind, Das Ziel besteht darin, den Prozentsatz zu bestimmen, in dem value_a gleich ist value_b.

Falscher Versuch:

select sum(case when o.value_a = o.value_b then 1 else 0 end) as nb_ok,
       sum(case when o.value_a != o.value_b then 1 else 0 end) as nb_not_ok,
       compute_percent(nb_ok,nb_not_ok)
from  my_obj as o
group by o.property_name;
Nach dem Login kopieren

Dieser Ansatz schlägt fehl, weil die Spalte nb_ok in der Abfrage nicht vorhanden ist.

Optimiert Lösung:

SELECT property_name
      ,(count(value_a = value_b OR NULL) * 100) / count(*) AS pct
FROM   my_obj
GROUP  BY 1;
Nach dem Login kopieren

Erklärung:

  • Der Operatorvorrang von = vor OR stellt sicher, dass der Vergleich zuerst ausgewertet wird.
  • count(value_a = value_b OR NULL) stellt sicher, dass NULL-Werte ignoriert werden.
  • Die Division von (count(value_a = value_b OR NULL) * 100) by count(*) berechnet den Prozentsatz.
  • count(*) stellt die Gesamtzahl der Zeilen dar, einschließlich NULL-Werten.

Ergebnis:

property_name | pct
--------------+----
 prop_1       | 17
 prop_2       | 43
Nach dem Login kopieren

Alternative für Fractional Ziffern:

SELECT property_name
      ,round((count(value_a = value_b OR NULL) * 100.0) / count(*), 2) AS pct
FROM   my_obj
GROUP  BY 1;
Nach dem Login kopieren

Diese Variante führt eine Bruchziffer ein, um Dezimalstellen beizubehalten.

Das obige ist der detaillierte Inhalt vonWie berechnet man den Prozentsatz übereinstimmender Werte in einer SQL-SELECT-Abfrage?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage