"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo puede una sola consulta SQL recuperar sumas distintas basadas en múltiples condiciones de cláusula?

¿Cómo puede una sola consulta SQL recuperar sumas distintas basadas en múltiples condiciones de cláusula?

Publicado el 2025-01-29
Navegar:116

How Can a Single SQL Query Retrieve Distinct Sums Based on Multiple WHERE Clause Conditions?

Use múltiples cláusulas para recuperar datos diferentes

En SQL, puede usar la cláusula WHERE para filtrar una fila específica para personalizar el método de datos recuperados de la tabla. Este problema propone el desafío de extraer dos conjuntos de datos diferentes de la misma tabla, y cada conjunto de datos se encuentra diferente donde las cláusulas.

La tabla de muestra "Transacciones" almacena los registros de transacciones financieras, que se caracterizan por su ID, ID de cuenta, ID de presupuesto, puntos y tipos de transacciones obtenidos. La tarea es calcular la suma de la acumulación de distribución de cada ID de presupuesto única y la suma de los puntos de distribución.

Para esto, puede construir una sola consulta SQL, que combina las cláusulas necesarias. La siguiente consulta logra el resultado del requerido:

Seleccione Presupuesto_id, Suma (caso When type = 'asignation' y luego puntos más 0 finalizar) como se asigna, Suma (caso When Type = 'Problema' y luego puntos más 0 final) según lo emitido De transacciones Grupo por presupuesto_id

SELECT budget_id, 
       SUM(CASE WHEN type = 'allocation' THEN points ELSE 0 END) AS allocated,
       SUM(CASE WHEN type = 'issue' THEN points ELSE 0 END) AS issued
FROM transactions
GROUP BY budget_id
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3