博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server 2005 导出包含(insert into)数据的SQL脚本 (使用存储过程)
阅读量:4923 次
发布时间:2019-06-11

本文共 2366 字,大约阅读时间需要 7 分钟。

--SQL Server里面导出SQL脚本(表数据的insert语句)

CREATE PROCEDURE dbo.UspOutputData
@tablename sysname
AS
declare @column varchar(1000)
declare @columndata varchar(1000)
declare @sql varchar(4000)
declare @xtype tinyint
declare @name sysname
declare @objectId int
declare @objectname sysname
declare @ident int
set nocount on
set @objectId=object_id(@tablename)
if @objectId is null -- 判断对象是否存在
begin
print 'The object not exists'
return
end
set @objectname=rtrim(object_name(@objectId))
if @objectname is null or charindex(@objectname,@tablename)=0 --此判断不严密
begin
print 'object not in current database'
return
end
if OBJECTPROPERTY(@objectId,'IsTable') < > 1 -- 判断对象是否是table
begin
print 'The object is not table'
return
end
select @ident=status&0x80 from syscolumns where and status&0x80=0x80
if @ident is not null
print 'SET IDENTITY_INSERT ON'
declare syscolumns_cursor cursor
for select c.name,c.xtype from syscolumns c where order by c.colid
open syscolumns_cursor
set @column=''
set @columndata=''
fetch next from syscolumns_cursor into @name,@xtype
while @@fetch_status < >-1
begin
if @@fetch_status < >-2
begin
if @xtype not in(189,34,35,99,98) --timestamp不需处理,image,text,ntext,sql_variant 暂时不处理
begin
set @column=@column+case when len(@column)=0 then'' else ','end+@name
set @columndata=@columndata+case when len(@columndata)=0 then '' else ','','','
end
+case when @xtype in(167,175) then --varchar,char
when @xtype in(231,239) then --nvarchar,nchar
when @xtype=61 then '''''''''+convert(char(23),'+@name+',121)+''''''''' --datetime
when @xtype=58 then '''''''''+convert(char(16),'+@name+',120)+''''''''' --smalldatetime
when @xtype=36 then '''''''''+convert(char(36),'+@name+')+''''''''' --uniqueidentifier
else @name end
end
end
fetch next from syscolumns_cursor into @name,@xtype
end
close syscolumns_cursor
deallocate syscolumns_cursor
set @sql='set nocount on select ''insert ) values(''as ''--'','+@columndata+','')'' from
print
exec(@sql)
if @ident is not null
print 'SET IDENTITY_INSERT OFF'
GO

 

使用方法:

exec UspOutputData 你的表名
选择【执行模式】为“以文本显示结果”,然后将运行后的结果存成.sql,加上用SQL Server生成的数据库脚本就可以了。

另外可以利用第三方工具,导出数据可以用powerbuilder。在database painter里面,用SQL选出,或者直接打开表,点击生成的list datawindow,然后在菜单file->save rows as->选择SQL,那么生成的SQL语句就包括建表和insert数据的SQL了。

补充说明:

sql2005怎么保存设置以文本格式显示结果

以表格格式显示结果。 CTRL+D

以文本格式显示结果。 CTRL+T

转载于:https://www.cnblogs.com/worfdream/articles/2429678.html

你可能感兴趣的文章
【Linux】在线求助man page与info page
查看>>
插入排序(Java实现)
查看>>
剑指offer 二叉树中和为某一值得路径
查看>>
LeetCode Distinct Subsequences
查看>>
MySQL中特有的函数If函数
查看>>
安装Python3.6.2报错:zipimport.ZipImportError: can't decompress data; zlib not available
查看>>
【蓝桥杯】入门训练 Fibonacci数列
查看>>
linux grep sed awk
查看>>
Java监听鼠标事件
查看>>
【贪心】合并果子
查看>>
0032 Java学习笔记-类加载机制-初步
查看>>
JAVA之反射(一)
查看>>
tomcat Host及Context 配置
查看>>
jQuery scroll事件实现监控滚动条分页示例(转)
查看>>
第1、2讲 linux基础介绍
查看>>
Java使用内存映射实现大文件的上传
查看>>
什么是反向代理,如何区别反向与正向代理
查看>>
线程的生命周期
查看>>
关于自适应屏幕,设置子元素浮动,父div不能包裹子div,子元素中内容溢出的问题。...
查看>>
Asp.Net文件上传之简单文件上传(上)
查看>>