SQL Server里面如何导出包含数据的SQL脚本

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介:
通常情况下,SQL Server里面的生成SQL脚本,只会包含数据库及表的字段结构,而不会包含表的数据,也就是SQL脚本里面只有Create database,Create table 这样的语句,没有insert into。
因为SQL Server并不包含这个功能,只能靠第三方的代码了。 
以下存储过程可以实现:
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 id=@objectid  and status&0x80=0x80    

if @ident  is  not  null    
print  'SET IDENTITY_INSERT '+@TableName+ ' ON'    

declare syscolumns_cursor  cursor    

for  select c. name,c.xtype  from  syscolumns c  where c.id=@objectid  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  '' '' '' '' '+'+@ name+ '+' '' '' '' ''  --varchar,char    
when @xtype  in(231,239)  then  '' 'N' '' '' '+'+@ name+ '+' '' '' '' ''  --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 '+@tablename+ '('+@ column+ ') values(' 'as ' '--'','+@columndata+','')'' from '+@tablename    

print '--'+@sql    
exec(@sql)    

if @ident is not null    
print 'SET IDENTITY_INSERT '+@TableName+' OFF'    

GO
 
使用方法: 

exec UspOutputData 你的表名 

选择【执行模式】为“以文本显示结果”,然后将运行后的结果存成.sql,加上用SQL Server生成的数据库脚本就可以了。
另外可以利用第三方工具,导出数据可以用powerbuilder。在database painter里面,用SQL选出,或者直接打开表,点击生成的list datawindow,然后在菜单file->save rows as->选择SQL,那么生成的SQL语句就包括建表和insert数据的SQL了。













本文转自周金桥51CTO博客,原文链接: http://blog.51cto.com/zhoufoxcn/166427  ,如需转载请自行联系原作者






相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
18天前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
1月前
|
SQL 关系型数据库 MySQL
|
22天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
31 0
|
1月前
|
SQL 数据库
执行 Transact-SQL 语句或批处理时发生了异常。 (Microsoft.SqlServer.ConnectionInfo)之解决方案
执行 Transact-SQL 语句或批处理时发生了异常。 (Microsoft.SqlServer.ConnectionInfo)之解决方案
230 0
|
2月前
|
关系型数据库 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)")
|
3月前
|
Java 测试技术 容器
从零到英雄:Struts 2 最佳实践——你的Web应用开发超级变身指南!
【8月更文挑战第31天】《Struts 2 最佳实践:从设计到部署的全流程指南》深入介绍如何利用 Struts 2 框架从项目设计到部署的全流程。从初始化配置到采用 MVC 设计模式,再到性能优化与测试,本书详细讲解了如何构建高效、稳定的 Web 应用。通过最佳实践和代码示例,帮助读者掌握 Struts 2 的核心功能,并确保应用的安全性和可维护性。无论是在项目初期还是后期运维,本书都是不可或缺的参考指南。
50 0
|
3月前
|
Java 应用服务中间件 Maven
从零到英雄:一步步构建你的首个 JSF 应用程序,揭开 JavaServer Faces 的神秘面纱
【8月更文挑战第31天】JavaServer Faces (JSF) 是一种强大的 Java EE 标准,用于构建企业级 Web 应用。它提供了丰富的组件库和声明式页面描述语言 Facelets,便于开发者快速开发功能完善且易于维护的 Web 应用。本文将指导你从零开始构建一个简单的 JSF 应用,包括环境搭建、依赖配置、Managed Bean 编写及 Facelets 页面设计。
95 0
|
3月前
|
SQL 关系型数据库 MySQL
【超全整理】SQL日期与时间函数大汇总会:MySQL与SQL Server双轨对比教学,助你轻松搞定时间数据处理难题!
【8月更文挑战第31天】本文介绍了在不同SQL数据库系统(如MySQL、SQL Server、Oracle)中常用的日期与时间函数,包括DATE、NOW()、EXTRACT()、DATE_ADD()、TIMESTAMPDIFF()及日期格式化等,并提供了具体示例。通过对比这些函数在各系统中的使用方法,帮助开发者更高效地处理日期时间数据,满足多种应用场景需求。
381 0
|
3月前
|
SQL 存储 数据管理
掌握SQL Server Integration Services (SSIS)精髓:从零开始构建自动化数据提取、转换与加载(ETL)流程,实现高效数据迁移与集成——轻松上手SSIS打造企业级数据管理利器
【8月更文挑战第31天】SQL Server Integration Services (SSIS) 是 Microsoft 提供的企业级数据集成平台,用于高效完成数据提取、转换和加载(ETL)任务。本文通过简单示例介绍 SSIS 的基本使用方法,包括创建数据包、配置数据源与目标以及自动化执行流程。首先确保安装了 SQL Server Data Tools (SSDT),然后在 Visual Studio 中创建新的 SSIS 项目,通过添加控制流和数据流组件,实现从 CSV 文件到 SQL Server 数据库的数据迁移。
190 0
|
2月前
|
SQL 数据库
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库。 SQL Server数据库出现823错误的可能原因有:数据库物理页面损坏、数据库物理页面校验值损坏导致无法识别该页面、断电或者文件系统问题导致页面丢失。
103 12
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
下一篇
无影云桌面