设为首页 收藏本站
查看: 1139|回复: 0

[经验分享] 常见SQL Server导入导出数据的几个工具

[复制链接]

尚未签到

发表于 2015-6-26 19:24:47 | 显示全部楼层 |阅读模式
  在我们的日常工作中,与数据库打交道的机会越来越多。这一篇文章我整理一下常见的SQL Server导入导出数据的几个工具
  
1. 数据导入导出向导
  这是一个可视化的工具,我放在首位,是由于它可以极大灵活地满足导入导出功能,而且是所见即所得的,易于使用。
  启动数据导入导出向导的方式有好多种,我自己习惯直接通过如下的命令启动(开始=》运行)
  dtswizard(顾名思义,它是一个wizard——向导,而且是与dts——data transfomation service有关的)
  从下图可以看出,这个工具支持多种不同类型的数据源(以及数据目标),它其实不仅仅限于SQL Server服务器。
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb.pnghttp://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_3.png
  【注意】如果是64位,这里的提供程序中找不到Excel和Access(我知道很多朋友都想导出这两种格式)
  
  该向导还可以通过在SQL Server Management Studio(SSMS)中启动。如果数据源或者数据目标是SQL Server的话,这是更加方便一些的。
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_4.png
  【注意】通过这样的方式启动的向导,却又可以看到Excel和Access(很神奇吧,http://www.xizhang.com/blogimages/SQL-Server_D62C/wlEmoticon-smilewithtongueout.png
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_5.png
  值得一提的是,这个导入导出向导还有一个好处,就是将我们经常需要导入导出的操作保存起来,如下图所示
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_6.png
  这里有一个所谓的SSIS Package,是什么意思呢?SSIS指的是SQL Server Integration Service,它是微软SQL Server BI平台的一个重要组件,用来设计和管理ETL解决方案。
  这个SSIS Package是一个扩展名为dtsx的特殊文件包,它可以通过一个所谓的Business Intelligence Developement Studio(BI Studio)打开查看,并且还可以进一步地编辑
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_7.pnghttp://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_8.png
  【备注】SSIS的讨论已经超出了本篇文章的范围。如有兴趣,请搜索我其他的文章。
  
  
2.BCP
  如果你要实现简单的数据导入导出,并且希望用脚本命令的方式,而不是图形界面来实现。那么可以考虑SQL Server提供的BCP实用工具。
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_9.pnghttp://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_10.png
  上图演示了如何将一个表导出为Excel文件,但如果想要根据一个查询导出的话,则可以按照下面这样的语法
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_11.png
  使用BCP也可以进行数据,只要将out改成In即可。
  【注意】使用bcp导出数据最大一个问题就是没有标题行
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_12.png
  
3. Bulk Insert和OpenRowSet
  如果想在T-SQL中直接导入Excel文件的数据,或者TXT文件的数据,则可以了解一下如下两个特殊的T-SQL语法
  BulkInsert的语法大致如下
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_13.png
  OpenRowSet的语法大致如下
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_14.png
  
  【备注】关于这两个语句的详细用法,请参考SQL Server自带的联机丛书。
  
4.FORXML和OPENXML
  如果想要导出导入XML格式的数据,则可以了解一下FORXML和OPENXML语法(它们是T-SQL语法,所以也可以很灵活地嵌入在我们的存储过程中)
USE Northwind
GO
SELECT * FROM Orders
FOR XML RAW('OrderItem'),
ELEMENTS XSINIL,
ROOT('Orders')
  上面的语法,可以将查询用XML格式返回,如下图所示
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_15.png
  【备注】FOR XML是SELECT的一个子句,有关更多用法,请参考SQL Server自带的联机丛书
  【备注】导出为XML格式的目的是为了更好地在不同应用程序之间共享。
  
  反过来,如果我们得到了一段XML数据,想将其导入到SQL Server中某个表中。可以考虑用OPENXML的语法。它的作用就是将XML还原为行集数据,然后就可以插入到我们的目的表中去了。
DECLARE @x XML
DECLARE @docHandle int
SET @x=N'

10248
VINET
3
1996-07-04T00:00:00
1996-08-01T00:00:00
1996-07-16T00:00:00
3
32.3800
Vins et alcools Chevalier
59 rue de lAbbaye
Reims

51100
France


10249
TOMSP
6
1996-07-05T00:00:00
1996-08-16T00:00:00
1996-07-10T00:00:00
1
11.6100
Toms Spezialitäten
Luisenstr. 48
Münster

44087
Germany
'

--第一步,做准备
EXEC SP_XML_PREPAREDOCUMENT @docHandle OUTPUT,@x
--第二步,openxml
INSERT Orders SELECT * FROM OPENXML(@docHandle,N'/Orders/OrderItem',2) WITH Orders
--第三步,销毁
EXEC sp_xml_removedocument @docHandle

  【备注】OPENXML还有其他更加复杂的用法,请参考SQL Server自带的联机丛书
  

5.使用Excel导出数据,或者建立查询
  最后介绍一种更加简单的方法,如果经常需要在Excel中进行数据库查询,并且据此做一些进一步的分析。最好的方法是在Excel中直接去导出数据,或者建立查询
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_16.pnghttp://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_17.pnghttp://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_18.png
http://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_19.pnghttp://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_20.pnghttp://www.xizhang.com/blogimages/SQL-Server_D62C/image_thumb_21.png
  这个做法的好处,是可以在现有Excel中,任何位置放置你需要的数据,而且需要注意的是,这些数据是链接到数据库的,也就是说,如果数据库的数据发生了更新,则只要刷新一下就可以了。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-80826-1-1.html 上篇帖子: Sql Server之旅——终点站 nolock引发的三级事件的一些思考 下篇帖子: SQL Server 2008 r2 安装过程图解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表