zoukankan      html  css  js  c++  java
  • 存储过程 动态为表生成自增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
  • 相关阅读:
    Entity Framework 教程
    C# yield
    表达式树系列文章汇总
    C#中静态与非静态方法比较
    谈谈对Spring IOC的理解
    工厂方法模式与IoC/DI
    通过配置的方式Autofac 《第三篇》
    Autofac 组件、服务、自动装配 《第二篇》
    Autofac 解释第一个例子 《第一篇》
    SQL Server索引调优系列
  • 原文地址:https://www.cnblogs.com/sgciviolence/p/2411140.html
Copyright © 2011-2022 走看看