cancel
Showing results for 
Search instead for 
Did you mean: 
cancel
Showing results for 
Search instead for 
Did you mean: 

Community Tip - You can Bookmark boards, posts or articles that you'd like to access again easily! X

Create 99 sequences in MS SQL

VasiliyRepecki
12-Amethyst

Create 99 sequences in MS SQL

Hi.

I need create 99 sequences that differ by number. I'm using MS SQL.

I tried to use something like that:

DECLARE @intFlag INT

SET @intFlag = 1

WHILE (@intFlag <= 99)

BEGIN

CREATE TABLE wt_sequence_KOIID_ + @intFlag + _seq (dummy CHAR(1), value BIGINT IDENTITY(1,1))

go

CREATE PROCEDURE wt_get_next_sequence_KOIID_ + @intFlag + _seq @returnValue BIGINT OUTPUT

AS

INSERT wt_sequence_KOIID_ + @intFlag + _seq (dummy) VALUES ('x')

SELECT @returnValue = SCOPE_IDENTITY()

go

SET @intFlag = @intFlag + 1

END

go

But there are too many errors. Can anyone help me and give correct sql code?

Thanks.

1 REPLY 1

I think this will work if you first store the CREATE TABLE and CREATE PROCEDURE commands as string variables, and then run EXEC on those variables. Try something like the below:

DECLARE @intFlag INT,@table nvarchar(300), @createTable nvarchar(300),@proc nvarchar(300), @createProc nvarchar(300)

SET @intFlag = 1

WHILE (@intFlag <= 99)

BEGIN

SET @table = 'wt_sequence_KOIID_' + cast(@intFlag as nvarchar) + '_seq'

SET @createTable = 'CREATE TABLE ' + @table + '(dummy CHAR(1), value BIGINT IDENTITY(1,1))'

EXEC(@createTable)

SET @proc = 'wt_get_next_sequence_KOIID_' + cast(@intFlag as nvarchar) + '_seq'

SET @createProc = 'CREATE PROCEDURE ' + @proc + '(@returnValue BIGINT OUTPUT)

AS

INSERT ' + @table + ' (dummy) VALUES (''x'')

SELECT @returnValue = SCOPE_IDENTITY()'

EXEC(@createProc)

SET @intFlag = @intFlag + 1

END

go

Announcements


Top Tags