Heim > Datenbank > MySQL-Tutorial > Wie kann ich Daten in MySQL mithilfe einer CASE-Anweisung komprimieren?

Wie kann ich Daten in MySQL mithilfe einer CASE-Anweisung komprimieren?

DDD
Freigeben: 2024-12-22 07:23:00
Original
496 Leute haben es durchsucht

How Can I Condense Data in MySQL Using a CASE Statement?

Kondensieren von Daten mit einer Case-Anweisung in MySQL

Beim Arbeiten mit Daten, die in relationalen Datenbanken gespeichert sind, kann es nützlich sein, den Inhalt von zu manipulieren Spalten basierend auf bestimmten Kriterien. Hier kommt die CASE-Anweisung ins Spiel, die eine Möglichkeit bietet, Spalten basierend auf bedingten Ausdrücken dynamisch Werte zuzuweisen, sodass Sie Ihre Daten für eine verbesserte Analyse und Berichterstellung neu strukturieren können.

Beispiel: Generieren von bedingten Spalten

Angenommen, Sie haben eine Datenbanktabelle namens „tbl_transaction“ mit Spalten für id, action_type, action_heading und action_amount. Um zwei neue Spalten, Einnahmenbetrag und Ausgabenbetrag, zu generieren, können wir die CASE-Anweisung nutzen, um sie basierend auf der Spalte „action_type“ bedingt zu füllen:

SELECT
    id,
    action_heading,
    CASE
        WHEN action_type = 'Income' THEN action_amount
        ELSE NULL
    END AS income_amt,
    CASE
        WHEN action_type = 'Expense' THEN action_amount
        ELSE NULL
    END AS expense_amt

FROM tbl_transaction;
Nach dem Login kopieren

Diese Abfrage erzeugt eine Ausgabe ähnlich der folgenden:

ID Heading Income Amt Expense Amt
1 ABC 1000 NULL
2 XYZ NULL 2000

Wie Sie sehen können, ist die Spalte „Einkommensbetrag“ mit Werten für Einkommenstransaktionen gefüllt, während die Spalte „Ausgabenbetrag“ mit Werten für Ausgaben gefüllt ist Transaktionen.

Alternative Syntax

MySQL bietet auch die IF()-Funktion als Alternative zur CASE-Anweisung zur Handhabung bedingter Operationen. In diesem Fall ist jedoch die CASE-Anweisung vorzuziehen, da sie vielseitiger und über verschiedene Datenbank-Engines hinweg portierbar ist.

Das obige ist der detaillierte Inhalt vonWie kann ich Daten in MySQL mithilfe einer CASE-Anweisung komprimieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage