| Subject | Re: [firebird-support] Re: Generator or table ? | 
|---|---|
| Author | Ann W. Harrison | 
| Post date | 2010-11-30T17:02:09Z | 
On 11/30/2010 10:59 AM, Elkins Villalona wrote:
an application where only one transaction calls the procedure.
In a heavily concurrent environment, you'll get large numbers
of Deadlock / Update Conflict errors on the select with lock
that will require you to rollback and retry the transaction.
Good luck,
Ann
            > I'm using the table approach, and it works pretty well for me. I got aYour procedure will be fine for a single user system, or for
> stored procedure like the one below to retrieve the next id number.
>
an application where only one transaction calls the procedure.
In a heavily concurrent environment, you'll get large numbers
of Deadlock / Update Conflict errors on the select with lock
that will require you to rollback and retry the transaction.
Good luck,
Ann
>
>
> create procedure SP_GET_ID (PID_NAME varchar(40))
> returns (RID integer)
> as
> BEGIN
> SELECT ID_SEQUENCE + 1
> FROM ID_TABLE
> WHERE ID_NAME =:PID_NAME
> WITH LOCK
> INTO :RID;
>
> UPDATE ID_TABLE
> SET ID_NAME = :RID
> WHERE ID_NAME =:PID_NAME;
>
> SUSPEND;
> END
>
>
>