存储过程 动态为表生成自增ID

由于不希望把主键字段设置成自增字段的主键,我通过动态创建一张对应表对应

复制代码
Create PROCEDURE [dbo].[proc_IdentityGetNewId]
(    
    @pTableName NVARCHAR(1000),
    @pIdentityId        bigint output
)
AS
DECLARE @StrSql NVARCHAR(4000),
        @ParameterList NVARCHAR(4000),
        @NewId        BIGINT    
BEGIN
    -- create Identity table
    IF not exists (SELECT 1 FROM  sysobjects WHERE  id = object_id('dbo.xx_Identity_' + @pTableName) and type = 'U')        
    BEGIN
        SET @StrSql = 'create table dbo.xx_Identity_' + @pTableName
        SET @StrSql = @StrSql  + ' ( IndentityId BIGINT identity )'        
        EXECUTE sp_executesql @StrSql
    END    
    set @StrSql = '
        -- insert new record
        INSERT dbo.xx_Identity_' + @pTableName + ' DEFAULT VALUES
        -- Retrieve identity
        SELECT @NewId = CONVERT(BIGINT, SCOPE_IDENTITY())
        -- Delete newly created record
        DELETE dbo.xx_Identity_' + @pTableName + ' WHERE IndentityId = @NewId'

    set @ParameterList = '@NewId bigint output'
    execute sp_executesql @StrSql, @ParameterList, @NewId output
    set @pIdentityId = @NewId
END
复制代码

 

posted @   violence  阅读(1833)  评论(0编辑  收藏  举报
努力加载评论中...
编辑推荐:
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
阅读排行:
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 本地部署DeepSeek后,没有好看的交互界面怎么行!
· 趁着过年的时候手搓了一个低代码框架
· 推荐一个DeepSeek 大模型的免费 API 项目!兼容OpenAI接口!
· 用 C# 插值字符串处理器写一个 sscanf
点击右上角即可分享
微信分享提示