FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
Como te habia mencionado antes, hacer pivot en sql (si usa un motor sin cláusula pivot) NO SE PUEDE HACER DE FORMA DIRECTA. No hay manera de hacerlo con joins ni nada parecido.
Toca, semi-manualmente, transponer filas a columnas, que se hace con cláusulas CASE. Mira los pasos: https://mode.com/sql-tutorial/sql-pivot-table/
__________________
El malabarista. |
#2
|
||||
|
||||
Gracias por vuestras respuestas. Estuve dando vueltas a vuestras sugerencias hasta que recordé que en otro punto del proyecto estoy usando este método y casi, casi lo logro. He dejado el query así:
Evidentemente estoy probando y faltan líneas en ese query. De todas formas, esta es la salida que obtengo: Sólo me falta que todas las celdas de cada tipo estén en una sola línea. |
#3
|
||||
|
||||
Recalco:
P.D: Esta es una limitación de la imperfecta implementación del sql del modelo relacional, pero no hay como arreglarla sin los pasos manuales requeridos...
__________________
El malabarista. |
#4
|
||||
|
||||
prueba con esto:
A ver si te sale... Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#5
|
||||
|
||||
JOIN no es la solucion. los join crecen las filas, que es lo que menos se quiere aqui. Necesitan son aggregates (SUMs, GROUP By, ...).
__________________
El malabarista. |
#6
|
||||
|
||||
Cita:
Efectivamente, necesito reducir el número de líneas. |
#7
|
||||
|
||||
Vale. Después de unas cuantas pruebas el query me queda así:
y la salida es esta, que es lo que buscaba: Tal vez se pueda hacer mejor, pero no se me ocurre como. Muchas gracias a todos por la ayuda. |
#8
|
||||
|
||||
Creo que lo lias mucho...
Saca los datos en filas. Nombre, Codigo, Total Luego agrupas: Campos de agrupacion + Casos FROM ( CONSULTA) GROUP BY Campos de Agrupacion En tu caso: SELECT DATOS.NOMBRE <- Campos para agrupar por filas, pueden ser varios SUM( CASE WHEN DATOS.CODIGO IN (1,2,3) THEN VOTOS ELSE 0 END ) as COLUMNA1, SUM( CASE WHEN DATOS.CODIGO IN (4,5,6) THEN VOTOS ELSE 0 END ) as COLUMNA2, ETC... FROM <- AQUI LA QUERY CON LOS DATOS EN FILAS. El resultado tiene alias DATOS, y devolvera las columnas NOMBRE, CODIGO y VOTOS o las que quieras... La query entre paréntesis ( SELECT A.Nombre, V.Codigo, V.Votos FROM SYSDBA134147 V INNER JOIN PROCESO A ON ( A.Campo1=V.Campo1) <- Desconozco tu modelo... <- Aqui puede ir la where que limite los datos ) DATOS <- FIN DE LA QUERY Aqui puede ir una where sobre el reslutado DATOS --AGRUPAS GROUP BY DATOS.NOMBRE Y a probar... Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#9
|
||||
|
||||
Gracias por la respuesta. He estado probando pero o no he montado bien el query o no sale lo que me hace falta. He dejado así el query:
Lo que necesito son los datos de cada uno de los casos y por ello no me hace falta el SUM; es irrelevante. Pero al ejecutar este query las salida es esta: Así no me vale porque el resultado del query lo necesito para definir un TQRChart. Me hace falta que los resultados de cada tipo queden en una misma fila. No obstante es una idea interesante que no se me había ocurrido. Última edición por Angel.Matilla fecha: 17-01-2020 a las 10:35:59. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Query con pivote | Angel.Matilla | Firebird e Interbase | 2 | 02-01-2020 15:58:44 |
Termino Involucion ¿? | amerika111 | Varios | 14 | 12-04-2012 01:08:43 |
SearchRec sale antes del termino | Paulao | Varios | 3 | 19-07-2011 14:04:36 |
Detectar término sessión | lucasarts_18 | HTML, Javascript y otros | 13 | 14-04-2008 17:43:05 |
Terminó de cargar la página? | Novás | Varios | 2 | 08-07-2006 16:24:35 |
|