Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

 
 
Herramientas Buscar en Tema Desplegado
  #7  
Antiguo 23-04-2010
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.806
Poder: 22
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Cita:
no hast tenido problemas si dos usuarios hacen una factura al mismo timepo
Pues no...
Lo que debes hacer es poner el código que busca el último numero de factura según la serie en el evento BeforePost del DataSet, como el ejemplo que te he dado anteriormente.

Este evento se ejecuta justo antes de grabar los datos. Debe ser rápido.

Mientras el usuario está metiendo los datos de la factura (cliente, fecha, forma de pago, etc.) otros usuarios pueden estar haciendo lo mismo. El estado del DataSet es dsInsert, pero todavía no está en la base.

Justo en el momento en que ejecutan el Post es donde abro una transacción, ejecuto el query que me da el número de factura y cierro la transacción. Esto solo toma una fracción de segundo, por lo que es casi imposible que otro usuario ejecute el post en ese mismo momento.

Nunca he tenido un error con esta forma de proceder.

De todos modos, si algún día hago un sistema en el que se entran 100 facturas (ofertas, pedidos o lo que sea) por minuto, me lo pensaré un poco mejor. Aunque esto creo que no existe.

Ten en cuenta que además de todo esto, tienes las series, por lo que tiene que darse el caso de que durante la fracción de segundo que tarda en traer el número de factura siguiente, otro usuario tiene que hacer el post con una factura de la misma serie.

Finalmente, debes contar con las PKs (Primary Keys). Estas evitarán que metas dos veces la misma factura. Por lo que el primero que hiciera el post, se quedaría con el número y el seguno obtendría un error. Si el error es de PK, vuelves a pedir un número.

Saludos

Última edición por duilioisola fecha: 23-04-2010 a las 01:01:43.
Responder Con Cita
 



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
Como Crear una base de datos Firebird desde delphi pmtzg Firebird e Interbase 14 08-06-2008 07:03:15
crear Stored Procedure desde delphi Milperrimo Firebird e Interbase 4 03-02-2008 18:52:53
Crear DB Firebird desde delphi totote Conexión con bases de datos 3 27-12-2007 02:25:17
uso desde delphi de un procedure de IB Giniromero Conexión con bases de datos 2 15-04-2004 11:00:24
Crear una BD Firebird desde Condigo delphi hibero Conexión con bases de datos 3 17-11-2003 14:52:40


La franja horaria es GMT +2. Ahora son las 00:06:37.


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