将表里的数据批量生成INSERT语句的存储过程 继续增强版

文章继续 桦仔兄的文章 将表里的数据批量生成INSERT语句的存储过程 增强版 继续增强...

本来打算将该内容回复于桦仔兄的文章的下面的,但是不知为何博客园就是不让提交!....

所以在这里贴出来吧,算作继续增加文章中解决的:根据查询条件自动生成插入脚本的需求,其实这种需求还是蛮常见的。

本文着重解决了文中的脚本的schema问题,给调整了下,现在脚本能自动识别出不同的schema下同名的表的语句

修改后脚本如下:

-- Author:      <桦仔>
-- Blog:        <http://www.cnblogs.com/lyhabc/>
-- Create date: <2014/10/18>
-- Description: <根据查询条件导出表数据的insert脚本>
-- =============================================
ALTER  PROCEDURE InsertGenerator
    (
      @tableName NVARCHAR(MAX),
      @whereClause NVARCHAR(MAX)
    )
AS 

--Then it includes a cursor to fetch column specific information (column name and the data type thereof)
--from information_schema.columns pseudo entity and loop through for building the INSERT and VALUES clauses
--of an INSERT DML statement.

    DECLARE @string NVARCHAR(MAX) --for storing the first half of INSERT statement
    DECLARE @stringData NVARCHAR(MAX) --for storing the data (VALUES) related statement
    DECLARE @dataType NVARCHAR(MAX) --data types returned for respective columns
    DECLARE @schemaName NVARCHAR(MAX) --schema name returned from sys.schemas
    DECLARE @schemaNameCount int--shema count
    DECLARE @QueryString  NVARCHAR(MAX) -- provide for the whole query, 

    set @QueryString=‘ ‘

     --如果有多个schema,选择其中一个schema
    SELECT @schemaNameCount=COUNT(*)
    FROM    sys.tables t
            INNER JOIN sys.schemas s ON t.schema_id = s.schema_id
    WHERE   t.name = @tableName

    WHILE(@schemaNameCount>0)
    BEGIN

    --如果有多个schema,依次指定
    select @schemaName = name
    from
    (
        SELECT ROW_NUMBER() over(order by  s.schema_id) RowID,s.name
        FROM    sys.tables t
                INNER JOIN sys.schemas s ON t.schema_id = s.schema_id
        WHERE   t.name =  @tableName
    ) as v
    where RowID=@schemaNameCount

    --Declare a cursor to retrieve column specific information
    --for the specified table
    DECLARE cursCol CURSOR FAST_FORWARD
    FOR
        SELECT  column_name ,
                data_type
        FROM    information_schema.columns
        WHERE   table_name = @tableName
                AND table_schema = @schemaName

    OPEN cursCol
    SET @string = ‘INSERT INTO [‘ + @schemaName + ‘].[‘ + @tableName + ‘](‘
    SET @stringData = ‘‘

    DECLARE @colName NVARCHAR(500)

    FETCH NEXT FROM cursCol INTO @colName, @dataType

    PRINT @schemaName
    PRINT @colName
    IF @@fetch_status <> 0
        BEGIN
            PRINT ‘Table ‘ + @tableName + ‘ not found, processing skipped.‘
            CLOSE curscol
            DEALLOCATE curscol
            RETURN
        END

    WHILE @@FETCH_STATUS = 0
        BEGIN
            IF @dataType IN ( ‘varchar‘, ‘char‘, ‘nchar‘, ‘nvarchar‘ )
                BEGIN
                       SET @stringData = @stringData + ‘‘‘‘‘‘‘‘‘+
                            isnull(‘ + @colName + ‘,‘‘‘‘)+‘‘‘‘‘‘,‘‘+‘
                END
            ELSE
                IF @dataType IN ( ‘text‘, ‘ntext‘ ) --if the datatype
                                 --is text or something else
                    BEGIN
                        SET @stringData = @stringData + ‘‘‘‘‘‘‘‘‘+
          isnull(cast(‘ + @colName + ‘ as nvarchar(max)),‘‘‘‘)+‘‘‘‘‘‘,‘‘+‘
                    END
                ELSE
                    IF @dataType = ‘money‘ --because money doesn‘t get converted
                       --from varchar implicitly
                        BEGIN
                            SET @stringData = @stringData
                                + ‘‘‘convert(money,‘‘‘‘‘‘+
        isnull(cast(‘ + @colName
                                + ‘ as nvarchar(max)),‘‘0.0000‘‘)+‘‘‘‘‘‘),‘‘+‘
                        END
                    ELSE
                        IF @dataType = ‘datetime‘
                            BEGIN
                                SET @stringData = @stringData
                                    + ‘‘‘convert(datetime,‘‘‘‘‘‘+
        isnull(cast(‘ + @colName + ‘ as nvarchar(max)),‘‘0‘‘)+‘‘‘‘‘‘),‘‘+‘
                            END
                        ELSE
                            IF @dataType = ‘image‘
                                BEGIN
                                    SET @stringData = @stringData + ‘‘‘‘‘‘‘‘‘+
       isnull(cast(convert(varbinary,‘ + @colName + ‘)
       as varchar(6)),‘‘0‘‘)+‘‘‘‘‘‘,‘‘+‘
                                END
                            ELSE --presuming the data type is int,bit,numeric,decimal
                            BEGIN
                                    SET @stringData = @stringData + ‘‘‘‘‘‘‘‘‘+
          isnull(cast(‘ + @colName + ‘ as nvarchar(max)),‘‘0‘‘)+‘‘‘‘‘‘,‘‘+‘
                                END

            SET @string = @string + ‘[‘ + @colName + ‘]‘ + ‘,‘

            FETCH NEXT FROM cursCol INTO @colName, @dataType
        END
--After both of the clauses are built, the VALUES clause contains a trailing comma which needs to be replaced with a single quote. The prefixed clause will only face removal of the trailing comma.

    DECLARE @Query NVARCHAR(MAX) -- provide for the whole query,
                              -- you may increase the size
    PRINT @whereClause
    IF ( @whereClause IS NOT NULL
         AND @whereClause <> ‘‘
       )
        BEGIN
            SET @query = ‘SELECT ‘‘‘ + SUBSTRING(@string, 0, LEN(@string))
                + ‘) VALUES(‘‘+ ‘ + SUBSTRING(@stringData, 0,
                                              LEN(@stringData) - 2)
                + ‘‘‘+‘‘)‘‘
   FROM ‘ +@schemaName+‘.‘+ @tableName + ‘ WHERE ‘ + @whereClause
            PRINT @query
           -- EXEC sp_executesql @query --load and run the built query
--Eventually, close and de-allocate the cursor created for columns information.
        END
    ELSE
  BEGIN
            SET @query = ‘SELECT ‘‘‘ + SUBSTRING(@string, 0, LEN(@string))
                + ‘) VALUES(‘‘+ ‘ + SUBSTRING(@stringData, 0,
                                              LEN(@stringData) - 2)
                + ‘‘‘+‘‘)‘‘
    FROM ‘ + @schemaName+‘.‘+ @tableName

        END

    CLOSE cursCol
    DEALLOCATE cursCol

    SET @schemaNameCount=@schemaNameCount-1
    IF(@schemaNameCount=0)
    BEGIN
       SET @QueryString=@QueryString+@query
    END
    ELSE
    BEGIN
        SET @QueryString=@QueryString+@query+‘ UNION ALL ‘
    END
    PRINT convert(varchar(max),@schemaNameCount)+‘---‘+@QueryString
    END
    EXEC sp_executesql @QueryString --load and run the built query
--Eventually, close and de-allocate the cursor created for columns information.

1、测试脚本如下:

INSERT INTO test1.[customer]([city],[region]) VALUES(‘2‘,‘3‘)

InsertGenerator ‘customer‘, null

效果如下:

2、增加筛选条件

InsertGenerator ‘customer‘, ‘city=1‘

其它内容可以参照桦仔兄的原文章地址。

时间: 2024-10-12 16:22:28

将表里的数据批量生成INSERT语句的存储过程 继续增强版的相关文章

将表里的数据批量生成INSERT语句的存储过程 增强版

原文:将表里的数据批量生成INSERT语句的存储过程 增强版 将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的库中 目前SQL Server里面是没有相关的工具根据查询条件来生成INSERT语句的,只有借助第三方工具(third party tools) 这种脚本网上也有很多,但是网上的脚本还是欠缺一些规范和功能,例如:我只想导出特定查询条件的数据,网上的脚本都是导出全表数据 如果表很大,对性能会有很大影响

将表里的数据批量生成INSERT语句的存储过程

有时候,我们需要将某个表里的数据全部导出来,迁移到另一个相同结构的库中,这里可以采取一个简便的方法,通过一个存储过程批量导出数据并生成SQL语句,非常方便.存储过程如下: CREATE proc [dbo].[spGenInsertSQL] (@tablename varchar(256)) as begin declare @sql varchar(max) declare @sqlValues varchar(max) set @sql =' (' set @sqlValues = 'val

用excel批量生成insert语句

excel表格中有A.B.C三列数据,分别对应TableName的UserId.UserName.UserPwd三个字段.如下图所示 在excel的D2的位置,也就是A.B.C列的后面一列,添加下面公式 =CONCATENATE("INSERT INTO TABLENAME(UserId,UserName,UserPwd) VALUES('"&A2&"','"&B2&"','"&C2&"'

MS SQLServer表数据生成Insert语句

关键词:SQLServer.表数据.生成Insert语句 反馈意见请联系:[email protected] 简介 数据库数据生成insert(MSSQL版),可将表中的数据生成insert或者update的sql脚本.比如您维护两个数据库,其中一个数据库中增加的数据也希望能够在另外一个数据中进行执行. 下载地址 下载地址:http://www.vidarsoft.cn/download/SQLInsert.zip Csdn下载地址:http://download.csdn.net/detail

【SQL Sever】将SQL Sever中的一个数据表的数据导出为insert语句

例如:这SQL   Sever中的一张数据表,想要将这张数据表中的数据  转化成一个一个的insert语句存储在txt的文档中,那么不论走到那里这个insert语句一执行,我们就能将这个数据表中的数据插入到另一个地方了. 1>在新建查询中,创建一个对象,这个对象就是用来产生这个对象的,名字叫proc_insert,我们可以创建多个不重名的对象,当然也可以删除这个对象. 1 create proc proc_insert (@tablename varchar(256)) 2 as 3 begin

SQLServer将表数据导出为Insert语句

从网上找到的方法,不过很不错,记录下来,也算是分享下~~ 有一个表,city,有列:cityID,cityName;将此表中所有数据,变为insert语句 select 'insert into tableName (cityID,cityName) values ('''+cityID+''','''+cityName+''')' as sqlStr from city; 这样就可以了; 如果在列中有其他类型,这样写会报错,可以用这个方法转换一下,STR(cityID,LEN(cityID))

python+jinja2实现接口数据批量生成工具

在做接口测试的时候,我们经常会遇到一种情况就是要对接口的参数进行各种可能的校验,手动修改很麻烦,尤其是那些接口参数有几十个甚至更多的,有没有一种方法可以批量的对指定参数做生成处理呢. 答案是肯定的! python的jinja2模板库可以很好的满足我们的需求,通过维护一个原始数据模板,将我们想要动态生成的变量模板化,就可以实现需求. 现在我们有这样的一个请求数据 { "abc":"123", "p2p":"123", "

手把手教你-----巧用Excel批量生成SQL语句,处理大量数据

在做系统或者做项目的时候,经常会遇到这样的要求:用户给我们发过来一些数据,要求我们把这些数据导入到数 据库中,对于少量的数据来说,用最原始的方法就可以解决,直接在SQL里面用语句来实现,但是如果有成千上万条的 数据呢?如果你还继续单独写SQL语句,估计写个几十条你就会有跳楼的冲动,其实有两种简单的方法: 1.将Excel的数据整理好,通过SQL的导入功能直接导入到数据库中,但是要保证数据库的字段和Excel的字段一致. 2.通过Excel生成相应的SQL语句,然后,放到SQL的新建查询中,执行.

SQL Server根据表或视图批量生成插入语句并BCP导出成文本

--声明变量 DECLARE @TableName VARCHAR(100),@RunStr VARCHAR(MAX),@RunRC VARCHAR(MAX),@FinalRun VARCHAR(MAX) --在master库创建数据载体,也可以建立在其他数据库,但一定要是实体表,因为BCP导出不支持临时表 IF OBJECT_ID('master.dbo.tempinsertstr') IS NOT NULL DROP TABLE master.dbo.tempinsertstr CREATE