代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
MSSQL
】
SQL Server自动生成INSERT语句
作者:
Dezai.CN
/ 发布于
2011/7/26
/
681
<div> <p class="cnt"><font face="Verdana">--这是一个可以将表中的数据自动生成INSERT语句的存储过程 --有个BUG,如果是自动增长列,数据也会被插入 --在查询分析器中执行完成后,可以从执行结果中自制出SQL脚本。 IF OBJECT_ID('spGenInsertSQL','P') IS NOT NULL DROP PROC spGenInsertSQL GO CREATE proc spGenInsertSQL (@tablename varchar(256)) as begin declare @sql varchar(8000) declare @sqlValues varchar(8000) set @sql =' (' set @sqlValues = 'values (''+' select @sqlValues = @sqlValues + cols + ' + '','' + ' ,@sql = @sql + '[' + name + '],' from (select case when xtype in (48,52,56,59,60,62,104,106,108,122,127) </font> <p class="cnt"><font face="Verdana">then 'case when '+ name +' is null then ''NULL'' else ' + 'cast('+ name + ' as varchar)'+' end'</font> <p class="cnt"><font face="Verdana">when xtype in (58,61)</font> <p class="cnt"><font face="Verdana">then 'case when '+ name +' is null then ''NULL'' else '+''''''''' + ' + 'cast('+ name +' as varchar)'+ '+'''''''''+' end'</font> <p class="cnt"><font face="Verdana">when xtype in (167)</font> <p class="cnt"><font face="Verdana">then 'case when '+ name +' is null then ''NULL'' else '+''''''''' + ' + 'replace('+ name+','''''''','''''''''''')' + '+'''''''''+' end'</font> <p class="cnt"><font face="Verdana">when xtype in (231)</font> <p class="cnt"><font face="Verdana">then 'case when '+ name +' is null then ''NULL'' else '+'''N'''''' + ' + 'replace('+ name+','''''''','''''''''''')' + '+'''''''''+' end'</font> <p class="cnt"><font face="Verdana">when xtype in (175)</font> <p class="cnt"><font face="Verdana">then 'case when '+ name +' is null then ''NULL'' else '+''''''''' + ' + 'cast(replace('+ name+','''''''','''''''''''') as Char(' + cast(length as varchar) + '))+'''''''''+' end'</font> <p class="cnt"><font face="Verdana">when xtype in (239)</font> <p class="cnt"><font face="Verdana">then 'case when '+ name +' is null then ''NULL'' else '+'''N'''''' + ' + 'cast(replace('+ name+','''''''','''''''''''') as Char(' + cast(length as varchar) + '))+'''''''''+' end'</font> <p class="cnt"><font face="Verdana">else '''NULL'''</font> <p class="cnt"><font face="Verdana">end as Cols,name</font> <p class="cnt"><font face="Verdana">from syscolumns </font> <p class="cnt"><font face="Verdana">where id = object_id(@tablename)</font> <p class="cnt"><font face="Verdana">) T set @sql ='select ''INSERT INTO ['+ @tablename + ']' + left(@sql,len(@sql)-1)+') ' + left(@sqlValues,len(@sqlValues)-4) + ')'' from '+@tablename print @sql exec (@sql) end GO</font> <p class="cnt"> <p class="cnt">执行如下语句测试结果: <div class="cnt"><font face="Verdana">exec spGenInsertSQL test From: <a href="http://www.cnblogs.com/shunyao8210/archive/2008/07/23/1249289.html" target="_blank"><font color="#5d5d5d">http://www.cnblogs.com/shunyao8210/archive/2008/07/23/1249289.html</font></a> PS:自增列需要调整一下 </font></div> <div class="cnt"><font face="Verdana">参考 SET IDENTITY_INSERT 表名 ON SET IDENTITY_INSERT 表名 OFF </font></div> </div>
试试其它关键字
自动生成INSERT语句
同语言下
.
SQL查询 多列合并成一行用逗号隔开
.
查看存储过程修改时间,最近执行时间
.
设置手动批量删除数据库相关进程
.
获取某个表中特定字段的所有字符串形式
.
SQL 如何去除重复的字符串
.
怎么去掉一个字段中的重复数据
.
String 去除空格 回车 换行 水平制表符
.
SQL查询和替换含有回车,空格,TAB
.
SQL SERVER 查询每日新增用户数量、次留数量
.
判断两个字符串是否存在相同的内容
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3