Coincido con [Casimiro] en que faltan datos.
Te diría que uses el WHERE para filtrar y el GROUP BY para agrupar, pero imagino que eso ya lo sabes.
Da la impresión de que lo que necesitras es una "visualización de los datos" con ese formato, así que depende de lo que estés utilizando para visualizarlos.
Por ejemplo, si unas un Grid de las DevExpress te diría que no debes hacer nada porque lo hace el componente, si estás usando un Report, deberás definir bandas, si estás usando un TreeView deberás lanzar varias consultas,...
żDónde quieres visualizar esa información?
|