【实用SQL脚本】生成数据发布的INSERT语句 推荐
2012-05-19 00:41
639 查看
【问题】DB结构的发布,SQL Server的管理器可以生成脚本;那么数据如何发布呢?
【思路】生成INSERT INTO ... VALUES...语句
【注1】原本一个小工具,也不过花了2个小时,并不值得写篇Blog。但一来,这个工具很多人需要;二来这是今天重感冒下做出来的(当我这篇blog写到一半时,感冒消失了),更显珍贵。
【注2】对于这个‘分享’:
想做:但是我发现新人们大多不太注重编码规范、牛人们不愿意平衡功能与成本,这段代码里面很有些参照价值;
可做:这是个纯粹的工具,不涉及机密;
能做:这个工具足够小,很容易说清楚、看明白。
还请读者们对作品本身发表意见。
【思路】生成INSERT INTO ... VALUES...语句
/*-- ============================================= -- Author: Yew -- Create date: 2012-05-18 -- Description: 生成数据发布的INSERT脚本 ----TestCode--------------------------- EXEC [TOOL].[Script_Insert] @Schema = 'COMMON' ,@Table = 'Config' ,@Filter = '[Key] LIKE ''test%'' ' ,@Field0 = '[Key]' ,@Field1 = 'SubKey' ,@Field2 = 'Value' ,@Field3 = null ,@Field4 = null EXEC [TOOL].[Script_Insert] @Schema = 'COMMON' ,@Table = 'MasterData' ,@Filter = 'Category = ''SheetItem_PreloadType'' ' ,@Field0 = 'Category' ,@Field1 = 'Code' ,@Field2 = 'Name' ,@Field3 = 'Ord' ,@Field4 = null ----History--------------------------- -- =============================================*/ ALTER PROCEDURE [TOOL].[Script_Insert] @Schema sysname = 'dbo' ,@Table sysname ,@Filter sysname = null ,@Field0 sysname ,@Field1 sysname = null ,@Field2 sysname = null ,@Field3 sysname = null ,@Field4 sysname = null AS BEGIN SET NOCOUNT ON; -- 0. Define Const DECLARE @NL varchar(2) --NewLine SET @NL = char(13) + char(10) DECLARE @vSql NVARCHAR(max) ,@objName sysname ,@fieldList sysname -- 1. prepare the statement IF @Schema = '' SET @Schema = 'dbo' SET @objName = @Schema + '.' + @Table SET @vSql = 'SET QUOTED_IDENTIFIER OFF; SELECT "INSERT INTO ' + @objName + '(' + @Field0 IF @Field1 IS NOT NULL SET @vSql = @vSql + ' ,' + @Field1 IF @Field2 IS NOT NULL SET @vSql = @vSql + ' ,' + @Field2 IF @Field3 IS NOT NULL SET @vSql = @vSql + ' ,' + @Field3 IF @Field4 IS NOT NULL SET @vSql = @vSql + ' ,' + @Field4 SET @vSql = @vSql + ' )' + @NL + 'VALUES(" + QuoteName(' + @Field0 + ', Char(39))' IF @Field1 IS NOT NULL SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field1 + ', ""), Char(39))' IF @Field2 IS NOT NULL SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field2 + ', ""), Char(39))' IF @Field3 IS NOT NULL SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field3 + ', ""), Char(39))' IF @Field4 IS NOT NULL SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field4 + ', ""), Char(39))' SET @vSql = @vSql + @NL + ' +")"' + @NL + 'FROM ' + @objName IF @Filter IS NOT NULL SET @vSql = @vSql + @NL + 'WHERE ' + @Filter -- 2.run it PRINT @vSql EXEC(@vSql) END
【注1】原本一个小工具,也不过花了2个小时,并不值得写篇Blog。但一来,这个工具很多人需要;二来这是今天重感冒下做出来的(当我这篇blog写到一半时,感冒消失了),更显珍贵。
【注2】对于这个‘分享’:
想做:但是我发现新人们大多不太注重编码规范、牛人们不愿意平衡功能与成本,这段代码里面很有些参照价值;
可做:这是个纯粹的工具,不涉及机密;
能做:这个工具足够小,很容易说清楚、看明白。
还请读者们对作品本身发表意见。
相关文章推荐
- 将表数据生成Insert脚本 比较好用的生成插入语句的SQL脚本
- 根据基本表结构及其数据生成INSERT 语句的SQL脚本
- 将表数据生成Insert脚本 比较好用的生成插入语句的SQL脚本
- [MSSQL]SQL Server里面导出SQL脚本(表数据的insert语句)(转)
- Microsoft SqlServer生成表数据Insert语句
- [MSSQL]SQL Server里面导出SQL脚本(表数据的insert语句)(转)
- 如何将sqlserver表中的数据导出sql语句或生成insert into语句
- 用脚本生成授权语句,输入参数包括用户名、IP、数据库名、要求的权限列表,输出为授权sql
- 把Excel数据生成Sql Insert语句
- 把excel数据生成sql insert语句
- Microsoft SqlServer生成表数据Insert语句
- Microsoft SqlServer生成表数据Insert语句
- 把excel数据生成sql insert语句
- 自动生成Insert数据的SQL脚本
- 自动生成Insert数据的SQL脚本
- 【转载】将sqlserver表中的数据导出sql语句或生成insert into语句
- 把excel数据生成sql insert语句
- 把excel数据生成sql insert语句
- 把excel数据生成sql insert语句
- SQL Server 2005导出表中数据的SQL脚本形式(即INSERT语句)