Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 12-11-2010
Avatar de gluglu
[gluglu] gluglu is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Málaga - España
Posts: 1.455
Poder: 23
gluglu Va por buen camino
Conseguir que Thread vea datos que todavían no han sido 'Commited' por la transacción

Saludos a tod@s !

Siempre he seguido la premisa de que un Thread debe abrir su propia base de datos, su propia transacción y sus propias tablas para que funcione 100% correcto y sin problemas. Para ello en el Thread en cuestión, creo un nuevo acceso a la BBDD, una nueva transacción y los Dataset's propios que voy a utilizar en el Thread.

Utilizo Firebird 2.1 y los componentes IBX, por cierto.

Mientras estoy introduciendo unos datos, quiero que se active ese thread en el 'background' para realizar una serie de cálculos. Pero estos cálculos se basan también en los datos que estoy introduciendo en ese momento, y que van a ser analizados.

Al no haber sido todavía 'commiteados' por la transacción, en el Thread no están visibles.

He intentado hacer una 'chapuzilla' que consiste en asignar a una de las tablas que creo en el Thread, la transacción correspondiente a los datos que estoy introduciendo. En principio funciona, pero cuando hago otra serie de operaciones es donde saltan de nuevo los problemas. Por ello está claro que el Thread necesita su propia independencia de datos.

Por eso no sé de qué manera hacer algo para que los datos que estoy introduciendo en ese momento fueran visibles en el Thread.

A lo mejor estoy pidiendo algo imposible, porque está claro que en Firebird no es posible ver los datos por otra transacción hasta que en la propia transacción se realice el Commit.

... ese es mi problema !

A lo mejor debatiendo podremos sacar alguna opción válida. Gracias en cualquier caso por vuestras ideas.
__________________
Piensa siempre en positivo !
Responder Con Cita
  #2  
Antiguo 12-11-2010
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.671
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
Hola gluglu, tanto tiempo
En principio, como bien dices, no es visible la transacción no confirmada. Aunque tal vez si nos explica algo más en detalle de lo que quieres hacer es posible que a alguno se nos ocurra alguna idea que pueda servirte.
Responder Con Cita
  #3  
Antiguo 13-11-2010
Avatar de gluglu
[gluglu] gluglu is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Málaga - España
Posts: 1.455
Poder: 23
gluglu Va por buen camino
En un programa de reservas de hotel, al crear una nueva reserva, quiero que un thread calcule la disponibilidad y ver si en el momento de la introducción d ela nueva reserva hay o no habitaciones suficientes.

El thread puede calcular la disponibilidad de las reservas ya confirmadas anteriormente y grabadas en la BBDD, pero necesita los datos de la reserva actual que todavia no se ha confirmado por la transacción para tener en cuenta esos valores.

Al poder introducir en una reserva un número ilimitado de número de habitaciones (aunque en el 99.99% sólo será de un tipo...), en principio pensé hacerlo directamente y únicamente sobre la base de datos.

Habiéndole dado muchas vueltas ya, la única opción factible que veo es pasarle los datos necesarios al thread mediante variables, tipo array or record en este caso, y una vez que el thread haya calculado ya la disponibilidad aplicarle además a los valores correspondientes, los que se han pasado mediante el array.

No veo otra posibilidad al final porque está claro que es 'imposible' que el thread vea los datos que estoy introduciendo en ese momento en la nueva reserva, hasta que no realice un Commit, que estaría por ver si el usuario quiere o no finalmente confirmar la reserva.

Así que creo que es la única opción, pasar esos datos al thread por variables que el thread pueda 'ver'.

Gracias de todas maneras como siempre por vuestro interés.

Saludos !
__________________
Piensa siempre en positivo !
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Conseguir Datos de la aplicacion. ErenioDhG Varios 1 29-08-2006 15:49:05
Una transaccion con dos bases de datos JavierSotillos Firebird e Interbase 0 13-06-2006 12:39:04
Thread bendito thread...se me pierde la ventana Seba.F1 API de Windows 5 02-02-2006 00:16:30
Foto de datos? - Transaccion Snapshot FlacoNet Firebird e Interbase 2 20-09-2005 20:30:14
DbExpres: Dod Bases de Datos, una sola Transacción. josemmerida Conexión con bases de datos 1 09-02-2005 19:43:58


La franja horaria es GMT +2. Ahora son las 05:01:23.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi