Lo más sencillo sería que utilizaras un TQuery para traer toda la información.
Enlazar tu reporte a este TQuery
Y utilizar bandas TQRGRoup para hacer las agrupaciones que necesitas.
Para los subtotales y totales, puedes utilizar varios TQRExpr y al final un banda tipo Summary.
|