【实用SQL脚本】生成数据发布的INSERT语句

简介:

【问题】DB结构的发布,SQL Server的管理器可以生成脚本;那么数据如何发布呢?

【思路】生成INSERT INTO ... VALUES...语句

 
  1. /*-- =============================================  
  2. -- Author:      Yew  
  3. -- Create date: 2012-05-18  
  4. -- Description: 生成数据发布的INSERT脚本  
  5.  
  6. ----TestCode---------------------------  
  7. EXEC [TOOL].[Script_Insert]  
  8.      @Schema    = 'COMMON' 
  9.     ,@Table     = 'Config' 
  10.     ,@Filter    = '[Key] LIKE ''test%'' ' 
  11.     ,@Field0    = '[Key]' 
  12.     ,@Field1    = 'SubKey' 
  13.     ,@Field2    = 'Value' 
  14.     ,@Field3    = null 
  15.     ,@Field4    = null 
  16.  
  17. EXEC [TOOL].[Script_Insert]  
  18.      @Schema    = 'COMMON' 
  19.     ,@Table     = 'MasterData' 
  20.     ,@Filter    = 'Category = ''SheetItem_PreloadType'' ' 
  21.     ,@Field0    = 'Category' 
  22.     ,@Field1    = 'Code' 
  23.     ,@Field2    = 'Name' 
  24.     ,@Field3    = 'Ord' 
  25.     ,@Field4    = null 
  26.  
  27. ----History---------------------------  
  28. -- =============================================*/  
  29. ALTER PROCEDURE [TOOL].[Script_Insert]  
  30.      @Schema    sysname = 'dbo' 
  31.     ,@Table     sysname  
  32.     ,@Filter    sysname = null 
  33.     ,@Field0    sysname  
  34.     ,@Field1    sysname = null 
  35.     ,@Field2    sysname = null 
  36.     ,@Field3    sysname = null 
  37.     ,@Field4    sysname = null 
  38. AS 
  39. BEGIN 
  40.     SET NOCOUNT ON;  
  41.  
  42.     -- 0. Define Const  
  43.     DECLARE @NL     varchar(2) --NewLine      
  44.     SET @NL = char(13) + char(10)  
  45.  
  46.     DECLARE @vSql   NVARCHAR(max)  
  47.         ,@objName   sysname  
  48.         ,@fieldList sysname  
  49.  
  50.     -- 1. prepare the statement   
  51.       
  52.     IF @Schema = '' 
  53.         SET @Schema = 'dbo' 
  54.           
  55.     SET @objName = @Schema + '.' + @Table 
  56.       
  57.     SET @vSql = 'SET QUOTED_IDENTIFIER OFF;  
  58.  
  59. SELECT   
  60. "INSERT INTO ' + @objName + '(' + @Field0   
  61.     IF @Field1 IS NOT NULL 
  62.         SET @vSql = @vSql + '   ,' + @Field1  
  63.     IF @Field2 IS NOT NULL 
  64.         SET @vSql = @vSql + '   ,' + @Field2  
  65.     IF @Field3 IS NOT NULL 
  66.         SET @vSql = @vSql + '   ,' + @Field3  
  67.     IF @Field4 IS NOT NULL 
  68.         SET @vSql = @vSql + '   ,' + @Field4  
  69.           
  70.     SET @vSql = @vSql + '   )'   
  71.         + @NL + 'VALUES(" + QuoteName(' + @Field0 + ', Char(39))' 
  72.  
  73.     IF @Field1 IS NOT NULL 
  74.         SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field1 + ', ""), Char(39))' 
  75.     IF @Field2 IS NOT NULL 
  76.         SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field2 + ', ""), Char(39))' 
  77.     IF @Field3 IS NOT NULL 
  78.         SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field3 + ', ""), Char(39))' 
  79.     IF @Field4 IS NOT NULL 
  80.         SET @vSql = @vSql + @NL + ' +", " + QuoteName(IsNull(' + @Field4 + ', ""), Char(39))' 
  81.  
  82.     SET @vSql = @vSql + @NL + ' +")"' 
  83.         + @NL + 'FROM ' + @objName  
  84.     IF @Filter IS NOT NULL 
  85.         SET @vSql = @vSql + @NL + 'WHERE ' + @Filter  
  86.               
  87.     -- 2.run it  
  88.     PRINT @vSql  
  89.     EXEC(@vSql)  
  90. END 


 

【注1】原本一个小工具,也不过花了2个小时,并不值得写篇Blog。但一来,这个工具很多人需要;二来这是今天重感冒下做出来的(当我这篇blog写到一半时,感冒消失了),更显珍贵。

【注2】对于这个‘分享’:

  • 想做:但是我发现新人们大多不太注重编码规范、牛人们不愿意平衡功能与成本,这段代码里面很有些参照价值;
  • 可做:这是个纯粹的工具,不涉及机密;
  • 能做:这个工具足够小,很容易说清楚、看明白。

还请读者们对作品本身发表意见。




















本文转自DavyYew 51CTO博客,原文链接:http://blog.51cto.com/davyyew/868414 ,如需转载请自行联系原作者




相关文章
|
8月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
简介:本文整理自阿里云高级技术专家李麟在Flink Forward Asia 2025新加坡站的分享,介绍了Flink 2.1 SQL在实时数据处理与AI融合方面的关键进展,包括AI函数集成、Join优化及未来发展方向,助力构建高效实时AI管道。
1089 43
|
8月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
本文整理自阿里云的高级技术专家、Apache Flink PMC 成员李麟老师在 Flink Forward Asia 2025 新加坡[1]站 —— 实时 AI 专场中的分享。将带来关于 Flink 2.1 版本中 SQL 在实时数据处理和 AI 方面进展的话题。
501 0
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
|
9月前
|
SQL
SQL如何只让特定列中只显示一行数据
SQL如何只让特定列中只显示一行数据
|
9月前
|
SQL
SQL中如何删除指定查询出来的数据
SQL中如何删除指定查询出来的数据
|
9月前
|
SQL 关系型数据库 MySQL
SQL如何对不同表的数据进行更新
本文介绍了如何将表A的Col1数据更新到表B的Col1中,分别提供了Microsoft SQL和MySQL的实现方法,并探讨了多表合并后更新的优化方式,如使用MERGE语句提升效率。适用于数据库数据同步与批量更新场景。
|
11月前
|
SQL 数据挖掘 关系型数据库
【SQL 周周练】一千条数据需要做一天,怎么用 SQL 处理电表数据(如何动态构造自然月)
题目来自于某位发帖人在某 Excel 论坛的求助,他需要将电表缴费数据按照缴费区间拆开后再按月份汇总。当时用手工处理数据,自称一千条数据就需要处理一天。我将这个问题转化为 SQL 题目。
412 12
|
10月前
|
SQL DataWorks 数据管理
SQL血缘分析实战!数据人必会的3大救命场景
1. 开源工具:Apache Atlas(元数据管理)、Spline(血缘追踪) 2. 企业级方案:阿里DataWorks血缘分析、腾讯云CDW血缘引擎 3. 自研技巧:在ETL脚本中植入版本水印,用注释记录业务逻辑变更 📌 重点总结:
|
SQL 存储 测试技术
SQLTest系列之参数化INSERT语句测试
# 场景引入 上文说书到“SQLTest系列之INSERT语句简单测试”,于是,菜鸟想深入了解:“在现实业务场景中,实际的表数据不可能是完全一样的。所以,我们需要完全模拟实际场景,如何将表数据完全参数化的方式来INSERT到表中呢?”。带着问题来研究SQLTest,问题快速的迎刃而解。 # 环境准备 随着研究的深入,菜鸟了解到SQLTest的强大,SQLTest支持将一个存储过程的输出结果集
3180 0
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
766 13
下一篇
开通oss服务