网站首页 > 编程文章 正文
朋友们,我们在使用SQLServer时,可能会碰到需要从外部的Excel读取数据的情况。比如我们实施ERP系统时,客户将数据整理在Excel中,要求我们批量导入系统。碰到这样的问题,应该如何解决呢?
总体来说,有两种方法可以使用。第一种方法就是通过MSSQL管理器自带的导入工具,一步步将Excel的工作表导入SQLServer成为一个数据表;另一种方法则是通过SQL语句直接读取Excel的工作表。如果您是开发人员,您会用哪一种方法呢?
当然是第二种方法最方便了,但也有朋友喜欢第一种方法。两种方法有本质的区别,导入方法要求Excel文件在MSSQL管理器本地即可,SQL直接查询方法要求Excel文件要放在SQLServer服务器上。
今天我们就两种方法的使用做详细的说明。
数据准备
为了便于说明,我准备了一个Excel文件。这是一个简单的销售表,Excel文件名称“SQL.XLS”、工作表名称为“销售表”。如下图所示:
利用MSSQL管理器的导入工具导入
这种方法比较保险,各种Excel文件基本都可以导入,而且待导入的Excel文件在管理器所在的电脑,而不是服务器。在我们无法控制服务器电脑时,这种方法就很有用。
操作步骤如下:
1、在数据库上点右键,弹出菜单选择导入。
2、选择Excel数据源。
3、选择本地Excel文件,并设置Excel的版本。
4、选择和设置导入到的数据库。
5、选择Excel工作表,并设置导入的表名
6、完成导入。
导入成功后,数据库中就会多出一个表。
使用SQL语句直接访问Excel文件
SQLServer提供了行集函数OPENROWSET实现对外部数据源的读取,要求待读取的Excel必须在服务器的某个硬盘下。
执行语法如下:
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0','Excel 12.0;Database=C:\SQL.xls;hdr=yes;imex=1', 销售表$);
如果我们直接执行可能会报错:
尚未注册 OLE DB 访问接口 "Microsoft.ACE.OLEDB.12.0"
碰到这样的情况,我们首先要启用Ad Hoc Distributed Queries,脚本如下:
EXEC sp_configure 'show advanced options',1 reconfigure EXEC sp_configure 'Ad Hoc Distributed Queries',1 RECONFIGURE GO EXEC master.dbo.sp_MSset_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'AllowInProcess', 1 EXEC master.dbo.sp_MSset_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'DynamicParameters', 1 GO
如果服务器没有安装AccessDatabaseEngine_X64.exe驱动,还需要先安装驱动,可以到微软官网https://www.microsoft.com/zh-cn/download/details.aspx?id=13255下载。如下图:
驱动安装成功时提示如下:
做完这些工作,我们就可以开始工作了。再次执行脚本:
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0','Excel 12.0;Database=C:\SQL.xls;hdr=yes;imex=1', 销售表$);
效果如下:
希望对您有所帮助!
猜你喜欢
- 2024-09-08 公共场所标示的常见英文表达(二)(公共场所英文标识图片及意思)
- 2024-09-08 “换壁纸”游戏玩家近千万、好评率96%:《壁纸引擎》名利双收
- 2024-09-08 Windows权限提升 —SQL Server/MSSQL数据库提权
- 2024-09-08 Delphi处理数据库方面的优势(delphi处理数据库方面的优势有哪些)
- 2024-09-08 《孤岛危机》厂商新作IGN评分出炉:7.5分差强人意
- 2024-09-08 当我们输入一条SQL查询语句时,发生了什么?
- 2024-09-08 用 100 行代码揭开 LLM 集成工具 LangChain 的神秘之处!
- 2024-09-08 重磅:SQLite数据库爆出漏洞,数以千计应用或受影响!
- 2024-09-08 架设传奇M2网关报错:服务器启动异常error210D
- 2024-09-08 高通官方解读骁龙712:游戏性能大幅增强
你 发表评论:
欢迎- 最近发表
-
- 数据不丢失 从Windows 11的DEV版降级到正式版
- Win11学院:在Windows11 25905预览版中如何启用Dev Drive
- DEVC++的卸载(devcon卸载驱动)
- win11 dev 开发版 升级攻略完整版
- 最新Windows11+Windows10系统各种版本永久激活密钥以及下载链接
- 想学Python,却还记不住语法?神仙书籍 python背记手册双手奉上
- 如何用Python语言开发大型服务器程序
- 30天Python 入门到精通(python零基础入门到精通)
- 入门扫盲:9本自学Python PDF书籍,让你避免踩坑,轻松变大神!
- 学好Python需要看的4本书推荐(学python好用的书)
- 标签列表
-
- spire.doc (59)
- system.data.oracleclient (61)
- 按键小精灵源码提取 (66)
- pyqt5designer教程 (65)
- 联想刷bios工具 (66)
- c#源码 (64)
- graphics.h头文件 (62)
- mysqldump下载 (66)
- sqljdbc4.jar下载 (56)
- libmp3lame (60)
- maven3.3.9 (63)
- 二调符号库 (57)
- 苹果ios字体下载 (56)
- git.exe下载 (68)
- diskgenius_winpe (72)
- pythoncrc16 (57)
- solidworks宏文件下载 (59)
- qt帮助文档中文版 (73)
- satacontroller (66)
- hgcad (64)
- bootimg.exe (69)
- android-gif-drawable (62)
- axure9元件库免费下载 (57)
- libmysqlclient.so.18 (58)
- springbootdemo (64)
本文暂时没有评论,来添加一个吧(●'◡'●)