This repository has been archived on 2024-11-29. You can view files and clone it, but cannot push or open issues or pull requests.
Tecsitel_FactuGES/BaseDatos/TablaContadores.pas

102 lines
2.8 KiB
ObjectPascal
Raw Permalink Normal View History

{
===============================================================================
Copyright (<EFBFBD>) 2002. Rodax Software.
===============================================================================
Los contenidos de este fichero son propiedad de Rodax Software titular del
copyright. Este fichero s<EFBFBD>lo podr<EFBFBD> ser copiado, distribuido y utilizado,
en su totalidad o en parte, con el permiso escrito de Rodax Software, o de
acuerdo con los t<EFBFBD>rminos y condiciones establecidas en el acuerdo/contrato
bajo el que se suministra.
-----------------------------------------------------------------------------
Web: www.rodax-software.com
===============================================================================
Fecha primera versi<EFBFBD>n: 03-12-2002
Versi<EFBFBD>n actual: 1.0.0
Fecha versi<EFBFBD>n actual: 03-12-2002
===============================================================================
Modificaciones:
Fecha Comentarios
---------------------------------------------------------------------------
===============================================================================
}
unit TablaContadores;
interface
uses
//Generales
Forms, SysUtils, Classes, Controls, IBSQL, cxGridDBTableView, cxCustomData, DB,
//Particulares
IBErrorCodes, IB,
//Aplicacion
Framework, StrFunc, Entidades, Constantes, BaseDatos,
//Contador
Contadores, RdxGestorContadores;
type
TdmTablaContadores = class(TDataModule)
public
function BloquearRC : boolean;
end;
var
dmTablaContadores: TdmTablaContadores;
implementation
{$R *.DFM}
{ TdmTablaContadores }
uses
Excepciones, Mensajes, Literales;
function TdmTablaContadores.BloquearRC: boolean;
{Esta funci<63>n bloquea la tabla de contadores para que ning<6E>n otro usuario pueda entrar}
var
oSQL : TIBSQL;
begin
Result := False;
oSQL := TIBSQL.Create(Self);
with oSQL do
begin
Database := dmBaseDatos.BD;
Transaction := dmBaseDatos.Transaccion;
SQL.Add('update CONTADORES ');
SQL.Add('set COMUN = (select COMUN from CONTADORES where CODIGOTABLA = 0) ');
SQL.Add('where CODIGOTABLA = 0');
try
Prepare;
ExecQuery;
Result := True;
except
on E : EIBError do
begin
case E.IBErrorCode of
isc_lock_conflict : begin
dmBaseDatos.Rollback;
VerMensaje(msgOpcTablaContBloqueada);
Result := False;
end
else begin
dmBaseDatos.Rollback;
TratarExcepcion(E);
Result := False;
end;
end;
end;
on E : Exception do begin
dmBaseDatos.Rollback;
TratarExcepcion(E);
Result := False;
end;
end;
end;
end;
end.