Ver Mensaje Individual
  #2  
Antiguo 23-11-2006
tefots tefots is offline
Miembro
 
Registrado: feb 2005
Posts: 108
Reputación: 20
tefots Va por buen camino
Cita:
Empezado por pvizcay
hola gente del foro, a ver si alguno se cruzo con esta duda que tengo y me puede ayudar a resolverla..!

simplificando un poco tengo dos tablas
FACTURAS(ID integer, ..., ID_TIPO integer)
TIPO_FACTURA (ID integer, DESC varchar)
de relación obvia; la tabla TIPO_FACTURA es dinámica y cambia, lo que pretendo es darle al usuario en un informe la posibilidad de filtrar los tipos de facturas que desea en un CheckListBox o algo por el estilo..

supongamos que el usuario elegió los tipos de factura con ID 3, 4, 5.. el informe se genera con un STORED PROCEDURE selecteable (porque procesa otras cosas que simplifiqué aca y además quiero desacoplarlo de la aplicación) llamado INFORME_FACT, ahora la pregunta es como le paso de manera limpia los IDs al procedure ya que:

si se los paso cada uno como un parámetro distinto tengo que suponer un número máximo de tipos de facturas (lo que por ahi en el ej. tiene sentido, pero en otras situación por el estilo no quiero limitar el número..)

y ahora suponiendo que no fuera un STORED PROCEDURE sino un SQL que se guarda en un TIBQuery normal, como lo generaría uds. SIN MODIFICAR EL TEXTO SQL...? (sino es fácil vas agregando and ID_TIPO = A, etc. por cada un al texto sql y listo)

se me ocurrió la solución puede estar creando tablas temporarias y haciendo un
SELECT * FROM FACTURAS
WHERE ID_TIPO IN (SELECT ID_TIPO FROM TEMPORARIA) ???
como se hace esto en FB de tal manera que funcione bien en multiusuario??

graciasss!!
con un stored procedure no puedes hacerlo , no se le pueden pasar arrays.

lo mas facil seria crear el sql que filtre los datos agregando 'and did_tipo=a and .....'

la otra forma mas complicada , en vez de crear una tabla temporal ,puedes tener una tabla ya creada, e insertar los datos en dicha tabla antes de hacer el query. esta tabla puede tener un campo que se valla incrementando para cada usuario que inserta un conjunto de datos (puedes obtenerlo de un generador , o ir incrementandolo tu) , y luego solo hay que hacer el mismo select , pero indicando el identificador que agrupa los datos añadidos.

SELECT * FROM FACTURAS
WHERE ID_TIPO IN (SELECT ID_TIPO FROM TEMPORARIA WHERE ID_CONJUNTODATOS=X) ???

asi cada usuario inserta / borra su conjunto de datos , que luego usa para hacer el query.
eso si , luego hay que borrar para que la tablatemporal no crezca hasta el infinito.
Responder Con Cita