Поделиться через


SYSK 124: IDENT_CURRENT Without an Identity Column

SQL Server’s function IDENT_CURRENT(‘tablename’) returns the last identity value set on a specified table.  While this is very useful, sometimes you need to get the next available primary key on a column that is not an identity field.  In this case,

SELECT IDENT_CURRENT (‘tablename’) will return NULL instead of the value you’re looking for.  If you find yourself in that situation, you should be able to use the code below to get the desired results:

 

SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;

DECLARE @Command nvarchar(512)

SET @Command = N'SELECT MAX(' + @TableName + '.' + @IdentityColumn +

      N') FROM ' + @TableName + ' WITH (XLOCK)';

BEGIN TRANSACTION

EXEC sp_executesql @Command

COMMIT TRANSACTION

 

Just create a function or stored procedure with the code above, and pass in the table name and the numeric column of your choice.

Comments

  • Anonymous
    May 11, 2006
    This works in SQL 2005 only, doesn't it?
  • Anonymous
    May 11, 2006
    I believe ident_current is available in sql 2000, but not in sql 7
  • Anonymous
    January 08, 2007
    Where is the information stored or maintained in the database, returned by IDENT_CURRENT function? Can we modify the vaue returned by this function?