July 15, 2010 at 12:04 am
mike 57299 (7/14/2010)
Paul,Do I need to do an explicit Begin Trans / Commit to make sure there is no duplicate sequence #'s?
Mike
Hey Mike,
No - and that's the beauty of it: it's an atomic operation (single UPDATE statement) which occurs within its own implicit transaction, as normal.
Paul
July 15, 2010 at 2:37 am
Paul White NZ (7/15/2010)
mike 57299 (7/14/2010)
Paul,Do I need to do an explicit Begin Trans / Commit to make sure there is no duplicate sequence #'s?
Mike
Hey Mike,
No - and that's the beauty of it: it's an atomic operation (single UPDATE statement) which occurs within its own implicit transaction, as normal.
Paul
It's very similar to the sequence generator I use in my DB, but consider that this solution can lead to very extensive row locks if run inside transactions.
Example:
Open a new query in SSMS and run:
BEGIN TRAN
EXEC dbo.usp_GenPK N'dbo.MyTable', @NewID OUTPUT;
WAITFOR DELAY '00:02';
COMMIT
Open a new query and run the same code. This second query waits for the first transaction to end.
If you don't mind gaps in the sequence, use a CLR procedure that implements autonomous transactions (not enlisted in the context connection's transaction) to generate the new id. Unfortunately, the permission to open a non-context connection in a CLR procedure must be granted marking the assembly as "external" or "unsafe".
I'm writing an article on this subject and I hope I get it finished soon.
-- Gianluca Sartori
July 15, 2010 at 3:54 am
Gianluca Sartori (7/15/2010)
...but consider that this solution can lead to very extensive row locks if run inside transactions...
Yes that's one of the things to watch out for, though it's not limited to row locks of course.
There's nothing wrong with using a CLR function to work around this (the EXTERNAL_ACCESS permission set is required, but that's not something to worry about). The other solution, in SQL Server 2008, is to use a loopback linked server, using sp_serveroption to set remote proc transaction promotion off. This allows autonomous transactions too.
I also wrote an article about this last year, but decided it would not be of interest to sufficient people to make it worth publishing.
Paul
July 15, 2010 at 4:28 am
Paul White NZ (7/15/2010)
The other solution, in SQL Server 2008, is to use a loopback linked server, using sp_serveroption to set remote proc transaction promotion off. This allows autonomous transactions too.
That's the simplest way to achieve it. Unfortunately it works only in SQL 2008 and I had to code in CLR because we're still on SQL 2005.
I also wrote an article about this last year, but decided it would not be of interest to sufficient people to make it worth publishing.
I strongly disagree. If it's well written (and I'm sure it is) it's always worth publishing. It's a subject that I see around sometimes and I think it can solve lots of problems. Autonomous transactions can save your life in many situations (sequences, logging, auditing) and other RDBMS vendors implement it natively (Oracle, DB2, Firebird, PostgreSQL...). It's a shame that MS hasn't decided yet to add this feature to SQL Server.
-- Gianluca Sartori
July 15, 2010 at 5:41 am
I strongly agree with Gianluca, Paul. Just because I don't have a clue what you meant (yet) doesn't mean that I won't need to know that the technique exists, and can refer back to your article when that happens. 😉
---------------------------------------------------------
How best to post your question[/url]
How to post performance problems[/url]
Tally Table:What it is and how it replaces a loop[/url]
"stewsterl 80804 (10/16/2009)I guess when you stop and try to understand the solution provided you not only learn, but save yourself some headaches when you need to make any slight changes."
July 15, 2010 at 7:23 am
Thanks for the encouragement guys 🙂
I will revisit my decision.
July 15, 2010 at 8:44 am
I'll chime in as well, Paul. People every day still use @@identity and forgo transaction log backups. If you've solved it, likely there are a few thousand people out there that don't understand it.
July 15, 2010 at 1:56 pm
Paul White NZ (7/15/2010)
Gianluca Sartori (7/15/2010)
...but consider that this solution can lead to very extensive row locks if run inside transactions...Yes that's one of the things to watch out for, though it's not limited to row locks of course.
There's nothing wrong with using a CLR function to work around this (the EXTERNAL_ACCESS permission set is required, but that's not something to worry about). The other solution, in SQL Server 2008, is to use a loopback linked server, using sp_serveroption to set remote proc transaction promotion off. This allows autonomous transactions too.
I also wrote an article about this last year, but decided it would not be of interest to sufficient people to make it worth publishing.
Paul
Another solution is to have a built-in "Increment" on the NextID proc and write code to know the correct answers ahead of time. No sense in a sequence table requiring RBAR.
--Jeff Moden
Change is inevitable... Change for the better is not.
Viewing 8 posts - 16 through 22 (of 22 total)
You must be logged in to reply to this topic. Login to reply