您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息
三六零分类信息网 > 铜川分类信息网,免费分类信息发布

Sql Server 数据库表查询结果导出为excel文件

2024/6/12 14:15:18发布98次查看
相信大家常常会遇到将sqlserver查询结果导出到excel的问题。如果导出的次数少,直接save results as...就是了; 1.1准备好查询语句 1.2选择数据库,启动导入和导出向导 1.3选择数据源 1.4选择目标 1.5 1.6 1.7 1.8 后续步骤不再附图,一直点下一步按钮就好。
相信大家常常会遇到将sqlserver查询结果导出到excel的问题。如果导出的次数少,,直接“save results as...”就是了;
1.1准备好查询语句
1.2选择数据库,启动导入和导出向导
1.3选择数据源
1.4选择目标
1.5
1.6
1.7
1.8
后续步骤不再附图,一直点“下一步”按钮就好。
2、但是当要分别在每个表取样,那就相当麻烦了。今天就为大家提供一个脱离office组件的可以将语句结果导出到excel的过程,希望会对大家有帮助!
---导出到excel
---使用说明:
-- 1.执行时所连接的服务器决定文件存放在哪个服务器
-- 2.远程查询语句中,要加上数据库名
alter proc exportfile
@querysql varchar(max)
,@server varchar(20)
,@user varchar(20)
,@password varchar(20)
,@filepath nvarchar(100) = 'c:exportfile.xls'
as
declare @tmp varchar(50) = '[##table' + convert(varchar(36),newid())+']'
begin try
declare @sql varchar(max),@datasource varchar(max)='';
--判断是否为远程服务器
if @server '.' and @server '127.0.0.1'
set @datasource = 'opendatasource(''sqloledb'',''data source='+@server+';user;password='+@password+''').'
--将结果集导出到指定的数据库
set @sql = replace(@querysql,' from ',' into '+@tmp+ ' from ' + @datasource)
print @sql
exec(@sql)
declare @columns varchar(max) = '',@data nvarchar(max)=''
select @columns = @columns + ',''' + name +''''--获取列名(xp_cmdshell导出文件没有列名)
,@data = @data + ',convert(nvarchar,[' + name +'])'--将结果集所在的字段更新为nvarchar(避免在列名和数据union的时候类型冲突)
from tempdb.sys.columns where object_id = object_id('tempdb..'+@tmp)
select @data = 'select ' + substring(@data,2,len(@data)) + ' from ' + @tmp
select @columns = 'select ' + substring(@columns,2,len(@columns))
--使用xp_cmdshell的bcp命令将数据导出
exec sp_configure 'xp_cmdshell',1
reconfigure
declare @cmd nvarchar(4000) = 'bcp ' + @columns+' union all ' + @data+' queryout ' + @filepath + ' -c -t'
print @cmd
exec sys.xp_cmdshell @cmd
exec sp_configure 'xp_cmdshell',0
reconfigure
exec('drop table ' + @tmp)
end try
begin catch
--处理异常
if object_id('tempdb..'+@tmp) is not null
exec('drop table ' + @tmp)
exec sp_configure 'xp_cmdshell',0
reconfigure
select error_message()
end catch
先不要着急使用,该版本是基于xp_cmdshell的,因为要创建文件,所以要保证你的用户能有文件管理的权限,通常简单点的方法就是将sql server的启动用户设置为本地系统用户
好了,现在我们来执行看看:
--查询分析器连接哪个服务器,文件就在哪个服务器上
--本地导出
exec dbo.exportfile @querysql = 'select * from sys.objects', -- varchar(max)
@server = '.', -- varchar(20)
@filepath = n'c:objects.xls' -- nvarchar(100)
--远程导出
exec dbo.exportfile @querysql = 'select * from master.sys.objects', -- varchar(max)
@server = '192.168.1.52', -- varchar(20)
@user = 'sa', -- varchar(20)
@password = 'sa', -- varchar(20)
@filepath = n'c:52objects.xls' -- nvarchar(100)
执行结果如下,显示导出条数,就没有报错,再看看你的c盘,多了2个文件就大功告成了:
铜川分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录