- Hay que instalar un driver ODBC en el cliente.
- Hay que configurar la conexión ODBC para que apunte a nuestra base de datos.
- Cada vez que el programa va a imprimir se abre una nueva conexión a la base de datos (imaginaos 20 usuarios trabajando a la vez).
- Puede faltar alguna DLL a la hora de instalar el programa en el cliente relacionada con conexiones ODBC.
Para solucionar esto vamos a ver como utilizar los objetos Direct Data View en el diseñador Rave Reports que nos van a evitar todos estos problemas.
PASANDO DE ADO, BDE y DBX
Los componentes Direct Data View que se encuentran en el editor Rave Designer permiten vincular los informes directamente con los componentes TRvDataSetConnection que se encuentren en nuestro programa Delphi, sin tener que establecer ninguna conexión de base de datos ni preocuparnos por drivers externos.
Funciona exactamente igual que los informes generados por QuickReport, donde el origen de datos es nuestro mismo programa, ahorrándonos conexiones extras. Vamos a ver un ejemplo de cómo generar un listado de clientes realizando una conexión directa entre Delphi y Rave Reports.
Los siguientes pasos serían para crear una conexión a Firebird desde Delphi:
1. Abrimos Delphi y creamos un formulario de prueba.
2. Insertamos un componente de la clase TIBDatabase en el formulario con el nombre BaseDatos.
3. Hacemos doble clic en el componente TIBDatabase y rellenamos los siguientes datos:
Connection: Remote
Server: 127.0.0.1
Database: D:\Desarrollo\DelphiAlLimite\Rave\BaseDatos.fdb
UserName: SYSDBA
Password: masterkey
Login Prompt: Desactivado
4. Añadimos un componente TIBTransaction y lo llamamos Transaccion.
5. Asociamos el componente Transaccion al componente BaseDatos a través de su propiedad DefaultTransaction.
6. En la propiedad DefaultDatabase del objeto TIBTransaction seleccionamos BaseDatos.
7. Insertamos en el formulario un componente TIBQuery con el nombre TClientes. En su propiedad Database seleccionamos BaseDatos. Y en su propiedad SQL ponemos:
SELECT * FROM CLIENTES
8. Hacemos doble clic sobre el componente TIBQuery y pulsamos la combinación de teclas CTRL + A para traernos los campos. Al hacer esto habrá dejado la base de datos abierta (BaseDatos). La dejamos así por ahora.
9. Insertamos en el formulario un componente TRvProject y lo llamamos Proyecto.
10. Insertamos otro componente de TRvSystem y lo llamamos Sistema. Asociamos este componente con TRvProject con su propiedad Engine.
11. Añadimos al formulario un componente TRvDataSetConnection que llamaremos DSClientes. En su propiedad DataSet elegimos TClientes.
Con toda esta movida ya tenemos una conexión a una base de datos Firebird y un DataSet especial para que Rave pueda recoger los datos.
CREANDO EL INFORME EN RAVE REPORTS
Dejando Delphi abierto con nuestra base de datos conectada (BaseDatos) ejecutamos el programa Rave Designer. Una vez estamos en el diseñador vamos a efectuar los siguiente pasos:
1. Pulsamos el botón New Data Object.
2. Seleccionamos Direct Data View y pulsamos Next.
3. Nos aparecerá una lista de conexiones abiertas en Delphi donde se estén utilizando componente TRvDataSetConnection. En nuestro caso aparecera DSClientes (DT). Lo seleccionamos y pulsamos Finish.
4. Renombramos el objeto DataView1 creado y lo llamamos Clientes.
5. Seleccionamos en el menú de arriba Tools -> Report Wizards -> Simple Table.
6. Seleccionamos Clientes y pulsamos Next.
7. Seleccionamos los campos ID, NOMBRE, DIRECCION, NIF, PROVINCIA y pulsamos Next.
8. Dejamos la ordenación como está y pulsamos Next.
9. En Report Title ponemos Listado de Clientes y pulsamos Next.
10. Seleccionamos la fuente a nuestro gusto y pulsamos Generate.
11. Guardamos el informe en el mismo directorio que nuestro proyecto de Delphi con el nombre Clientes.rav.
Si pulsamos el botón de la impresora y mostramos una vista previa veremos como se trae directamente de Delphi los datos y los imprime.
La potencia que nos da esta forma de trabajar es enorme, ya que es nuestro proyecto Delphi el que suministra los datos, siendo posible filtrar y ordenar tablas de bases de datos a nuestro antojo sin que Rave Reports no tenga que enterarse de donde proceden los datos.
Ya podemos cerrar el programa Rave Designer. Ahora vamos a ver como lanzar el informe desde Delphi.
LANZANDO EL INFORME RAVE DESDE DELPHI
En Delphi ya podemos desconectar la base de datos en tiempo de diseño. Para lanzar el listado hacemos lo siguiente:
begin
BaseDatos.DatabaseName := '127.0.0.1:' + ExtractFilePath( Application.ExeName ) + 'BaseDatos.fdb';
try
BaseDatos.Open;
except
raise;
end;
TClientes.Open;
Proyecto.ProjectFile := ExtractFilePath( Application.ExeName ) + 'clientes.rav';
Proyecto.Execute;
end;
Esto abrirá la base de datos Firebird, también la tabla clientes y ejecutará el informe.
A partir de aquí podemos hacer lo que nos venga en gana para modificar el listado de clientes: modificar la SQL para cambiar la ordenación, filtrar por ID, NIF, etc.
FILTRANDO TABLAS MAESTRO/DETALLE EN RAVE REPORTS
Utilizando las tablas FACTURAS y DETALLEFAC que vimos anteriormente podemos filtrar el detalle de la factura a partir de la cabecera. Resumiendo un poco, los pasos serían los siguientes:
1. Vinculamos las tablas FACTURAS y DETALLEFAC en el informe utilizando componentes Direct Data View.
2. Volvemos a vincular los campos con estos dos componentes.
3. Seleccionamos la banda Detalle y configuramos las siguientes propiedades:
MasterDataView: Facturas
MasterKey: ID
DetailKey: IDFACTURA
Con estos simples pasos imprimiremos las facturas desde Delphi sin tener que preocuparnos de filtrar la tabla detalle. También habría que crear otro objeto Direct Data View para enlazar a la tabla CLIENTES y poder traernos los datos. Para imprimir la factura desde Delphi filtrando al cliente:
begin
BaseDatos.DatabaseName := '127.0.0.1:' + ExtractFilePath( Application.ExeName ) + 'BaseDatos.fdb';
try
BaseDatos.Open;
except
raise;
end;
// Filtramos la factura
TFacturas.SQL.Clear;
TFacturas.SQL.Add( 'SELECT * FROM FACTURAS WHERE ID=2' );
TFacturas.Open;
// Filtramos el cliente según la factura
TClientes.SQL.Clear;
TClientes.SQL.Add( 'SELECT * FROM CLIENTES WHERE ID=' + TFacturas.FieldByName( 'IDCLIENTE' ).AsString );
TClientes.Open;
// Abrimos el detalle (ya se encarga Rave de filtrarlo respecto a la cabecera)
TDetalleFac.Open;
// Lanzamos el informe
Proyecto.ProjectFile := ExtractFilePath( Application.ExeName ) + 'factura.rav';
Proyecto.Execute;
end;
Se supone que hemos creado en el formulario de Delphi dos componentes TIBQuery llamados TFactura y TDetalleFac para la cabecera y detalle de la factura.
Con esto finalizamos la introducción al editor de informes Rave Reports.
Pruebas realizadas en Delphi 7, Rave Reports 5.0 y Firebird 2.0.