sqlserver 表中记录生成insert,可以加条件,可以生成建表语句
sqlserver 表中记录生成insert,可以加条件,可以生成建表语句
create PROCEDURE [sp_getinsert]
(
@tablename VARCHAR(256) , --如果非默认架构,可以加上架构名 例如:schema1.tablename
@where VARCHAR(1000) = '',
@create BIT =0
)
AS
BEGIN
SET NOCOUNT ON; IF @create=1
EXEC sp_gettext @name=@tablename,@identity=1,@index=2; DECLARE @sqlstr VARCHAR(max)= '';
DECLARE @sqlstr1 VARCHAR(max);
DECLARE @sqlstr2 VARCHAR(max) ,
@HasIdentity BIT; SET @HasIdentity = OBJECTPROPERTY(OBJECT_ID(@tablename),
'TableHasIdentity'); IF ( @HasIdentity = 1 )
SET @sqlstr = @sqlstr + ' select ''SET IDENTITY_INSERT '
+ @tablename + ' ON'' UNION ALL ' + CHAR(10); SELECT @sqlstr = @sqlstr + 'select ''insert ' + @tablename;
SELECT @sqlstr1 = '';
SELECT @sqlstr2 = ' (';
SELECT @sqlstr1 = ' values ( ''+';
SELECT @sqlstr1 = @sqlstr1 + col + '+'',''+',
@sqlstr2 = @sqlstr2 + QUOTENAME(name) + ','
FROM (
SELECT CASE
-- when a.xtype =173 then 'case when '+QUOTENAME(a.name)+' is null then ''NULL'' else '+'convert(varchar('+convert(varchar(4),a.length*2+2)+'),'+QUOTENAME(a.name) +')'+' end'
WHEN a.xtype = 127
THEN 'case when ' + QUOTENAME(a.name)+(CASE WHEN collation ='Chinese_PRC_CI_AS' THEN '' ELSE ' collate '+collation COLLATE DATABASE_DEFAULT end)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(20),'
+ QUOTENAME(a.name) + ')' + ' end'
WHEN a.xtype = 104
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(1),'
+ QUOTENAME(a.name) + ')' + ' end'
WHEN a.xtype = 175
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ '''''''''+' + 'replace('
+ QUOTENAME(a.name)
+ ','''''''','''''''''''')'
+ '+''''''''' + ' end'
WHEN a.xtype = 61
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ '''''''''+' + 'convert(varchar(23),'
+ QUOTENAME(a.name) + ',121)'
+ '+''''''''' + ' end'
WHEN a.xtype = 106
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar('
+ CONVERT(VARCHAR(4), a.xprec + 2)
+ '),' + QUOTENAME(a.name) + ')'
+ ' end'
WHEN a.xtype = 62
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(23),'
+ QUOTENAME(a.name) + ',2)' + ' end'
WHEN a.xtype = 56
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(11),'
+ QUOTENAME(a.name) + ')' + ' end'
WHEN a.xtype = 60
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(22),'
+ QUOTENAME(a.name) + ')' + ' end'
WHEN a.xtype = 239
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ '''''''''+' + 'replace('
+ QUOTENAME(a.name)
+ ','''''''','''''''''''')'
+ '+''''''''' + ' end'
WHEN a.xtype = 108
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar('
+ CONVERT(VARCHAR(4), a.xprec + 2)
+ '),' + QUOTENAME(a.name) + ')'
+ ' end'
WHEN a.xtype = 231
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ '''''''''+' + 'replace('
+ QUOTENAME(a.name)
+ ','''''''','''''''''''')'
+ '+''''''''' + ' end'
WHEN a.xtype = 59
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(23),'
+ QUOTENAME(a.name) + ',2)' + ' end'
WHEN a.xtype = 58
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ '''''''''+' + 'convert(varchar(23),'
+ QUOTENAME(a.name) + ',121)'
+ '+''''''''' + ' end'
WHEN a.xtype = 52
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(12),'
+ QUOTENAME(a.name) + ')' + ' end'
WHEN a.xtype = 122
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(22),'
+ QUOTENAME(a.name) + ')' + ' end'
WHEN a.xtype = 48
THEN 'case when ' + QUOTENAME(a.name)
+ ' is null then ''NULL'' else '
+ 'convert(varchar(6),'
+ QUOTENAME(a.name) + ')' + ' end'
-- when a.xtype =165 then 'case when '+QUOTENAME(a.name)+' is null then ''NULL'' else '+'convert(varchar('+convert(varchar(4),a.length*2+2)+'),'+QUOTENAME(a.name) +')'+' end'
WHEN a.xtype = 167
THEN 'case when ' + QUOTENAME(a.name)+(CASE WHEN collation ='Chinese_PRC_CI_AS' THEN '' ELSE ' collate '+collation COLLATE DATABASE_DEFAULT end)
+ ' is null then ''NULL'' else '
+ '''''''''+' + 'replace('
+ QUOTENAME(a.name)+(CASE WHEN collation ='Chinese_PRC_CI_AS' THEN '' ELSE ' collate '+collation COLLATE DATABASE_DEFAULT end)
+ ','''''''','''''''''''')'
+ '+''''''''' + ' end'
ELSE '''NULL'''
END AS col, a.colid, a.name
FROM syscolumns a
WHERE a.id = OBJECT_ID(@tablename)
AND a.xtype <> 189
AND a.xtype <> 34
AND a.xtype <> 35
AND a.xtype <> 36
) t
ORDER BY colid; SELECT @sqlstr = @sqlstr + LEFT(@sqlstr2, LEN(@sqlstr2) - 1) + ') '
+ LEFT(@sqlstr1, LEN(@sqlstr1) - 3) + ')'' from ' + @tablename
+ ( CASE WHEN @where IS NOT NULL
AND LEN(@where) > 0 THEN ' where ' + @where
ELSE ''
END ); IF ( @HasIdentity = 1 )
SET @sqlstr = @sqlstr
+ ' UNION ALL select ''SET IDENTITY_INSERT ' + @tablename
+ ' OFF'' ' + CHAR(10); PRINT @sqlstr;
EXEC( @sqlstr);
SET NOCOUNT OFF;
END;
调用示例:
exec [sp_getinsert] @tablename='tablename',@where='id>5 ',@create=0
sqlserver 表中记录生成insert,可以加条件,可以生成建表语句的更多相关文章
- TRUNCATE 删除表,无法回退。默认选择为整个表的内容,所以不能加条件。
TRUNCATE 删除表,无法回退.默认选择为整个表的内容,所以不能加条件.DELETE 删除表,可以回退.可以带where 条件.建议使用delete.但是TRUNCATE 删除表数据比delete ...
- SQL语句的使用,SELECT - 从数据库表中获取数据 UPDATE - 更新数据库表中的数据 DELETE - 从数据库表中删除数据 INSERT INTO - 向数据库表中插入数据
SQL DML 和 DDL 可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL). SQL (结构化查询语言)是用于执行查询的语法. 但是 SQL 语言也包含用于更新. ...
- 取得表中数据的insert语句
Build Insert Statements for the Existing Data in Tables 下面这个脚本实现了取得一个非空表中的所有insert语句 This script bui ...
- NSIS:在注册表中记录安装路径以便重装或升级时读取
原文 NSIS:在注册表中记录安装路径以便重装或升级时读取 在NSIS中,这个功能是非常有用的,可以避免用户把程序安装到多个位置的尴尬. 第1步:在“安装目录选择页面”前面加入以下代码: 1 !def ...
- oracle数据库误删的表以及表中记录的恢复
oracle数据库误删的表以及表中记录的恢复 一.表的恢复 对误删的表,只要没有使用PURGE永久删除选项,那么从flash back区恢复回来希望是挺大的.一般步骤有: --1.从flash bac ...
- sql 循环表中记录
=========================================================================循环排序查询数据=================== ...
- hbase使用MapReduce操作3(实现将 fruit 表中的一部分数据,通过 MR 迁入到 fruit_mr 表中)
Runner类 实现将 fruit 表中的一部分数据,通过 MR 迁入到 fruit_mr 表中. package com.yjsj.hbase_mr; import org.apache.hadoo ...
- SQL迅速增加表中记录语句
很多时候我么需要为表中疯狂增加N条记录,那么我们该使用什么语句实现该功能呢?如下: insert into 表名(字段1,字段2,字段3....) select 字段1,字段2,字段3.... fr ...
- 【转】MySQL数据表中记录不存在则插入,存在则更新
mysql 记录不存在时插入在 MySQL 中,插入(insert)一条记录很简单,但是一些特殊应用,在插入记录前,需要检查这条记录是否已经存在,只有当记录不存在时才执行插入操作,本文介绍的就是这个问 ...
随机推荐
- 吸血鬼日记第一季/全集The Vampire Diaries迅雷下载
本季The Vampire Diaries 1 第一季(2009)看点: <吸血鬼日记>由美国女作家L.J.史密斯的同名畅销系列小说改编而成.4个月前一场可怕的车祸夺去了他们双亲的生命,但 ...
- 《例说XBee无线模块开发》
<例说XBee无线模块开发> 基本信息 原书名:The Hands-on XBee Lab Manual:Experiments that Teach you XBee Wireless ...
- C# 异步编程Task整理(二)异常捕捉
一.在任务并行库中,如果对任务运行Wait.WaitAny.WaitAll等方法,或者求Result属性,都能捕获到AggregateException异常. 可以将AggregateExceptio ...
- 如何解决rar文件解压缩失败
附件经常会是一系列的压缩文件,下载是默认文件名是一个随机数字.因而下载完会出现压缩文件解压缩失败解决方法:下载时重命名为带一定顺序的文件名,如文件1,文件2,文件3等 如何解决单个文件解压失败?论坛中 ...
- glyphicons-halflings-regular.woff2:1 Failed to load resource: the server responded with a status of 404 (Not Found)解决Web部署 svg/woff/woff2字体 404错误
问题:最近在IIS上部署web项目的时候,发现浏览器总是报找不到woff.woff2字体的错误.导致浏览器加载字体报404错误,白白消耗了100-200毫秒的加载时间. 原因:因为服务器IIS不认SV ...
- head first--------------state pattern
head first----------浅谈状态模式 状态模式:允许对象在内部状态改变时改变它的行为,对象看起来好像修改了它的类 实现代码如下: package com.cl ...
- Windows server 2008 r2 如何开启Win7的Aero效果 (转)
Aero 桌面体验为开放式外观提供了类似于玻璃的窗口. 它包括与众不同的直观样式,将轻型透明的窗口外观与强大的图形高级功能结合在一起.您可以享受具有视觉冲击力的效果和外观,并可从更快地访问程序中获益. ...
- iOS开发-邮件发送
Web开发的时候邮箱注册登录是必不可少的,手机号可以更换,不过相对而言,邮箱只是用于比较重要的时候用到,比如找工作的时候必填的邮箱,注册网站会员的邮箱验证.现在的手机和Web的其实操作是一样的,大多数 ...
- Mysql 高可用方案
1 mysql分布式数据库,如 mycat https://www.cnblogs.com/zzsdream/articles/6650690.html 2 读写分离,mysql主从复制+mysql ...
- 【Spark】Spark Streaming 动态更新filter关注的内容
Spark Streaming 动态更新filter关注的内容 spark streaming new thread on driver_百度搜索 (1 封私信)Spark Streaming 动态更 ...