最近在做这个问题的时候,发现网上很多资料不是很全,而且有些是有错的,现在我把问题解决了,特把相应的方法贴出来。
在执行插入语句前,需要做下面几步操作:
1、从开始菜单进入到 配置工具 > sql server 2005 外围应用配置器 > 服务和连接的外围配置器 > Datebase Engine > 服务,然后重启sqlserver服务。(在数据库非正常关闭之后,可能会出现,“没法初始化数据源的错误”,此时重启一下sqlserver服务就可以了)
2、然后运行 regedit 进入注册表编辑器 HKEY_LOCAL_MACHINESOFTWAREMicrosoftMicrosoft SQL ServerMSSQL.1ProvidersMicrosoft.Jet.OLEDB.4.0 新建DWORD (64位值)名为DisallowAdhocAccess 值为0.
3、注意:
3.1、把需要导入的Execl文件关闭;
3.2、配置工具 > SQL Server 外围配置管理器 > 功能的外围应用配置器 > Database Engine > 即席远程查询 > 启用OPENROWSET 和 OPENDATASOURCE 支持 (勾选上)
3、在执行插入语句前,必须先打开这个组件服务:
exec sp_configure ‘show advanced options’,1 reconfigure exec sp_configure ‘Ad Hoc Distributed Queries’,1 reconfigure |
注意:在每次用完之后,记得把它关闭。
exec sp_configure ‘Ad Hoc Distributed Queries’,0 reconfigure exec sp_configure ‘show advanced options’,0 reconfigure |
4、插入语句:
/*新建表y,同时插入数据*/ select * into y from OpenDataSource(‘Microsoft.Jet.OLEDB.4.0’,’Data Source=”G:1.xls”;Extended properties= “Excel 8.0;HDR=YES;IMEX=1″‘)…[Sheet1$] /*新建表y,同时插入数据*/ /*插入到已有的表x中*/ insert into x select * from OPENROWSET(‘MICROSOFT.JET.OLEDB.4.0′,’Excel 8.0;HDR=YES;DATABASE=G:1.xls’,Sheet1$); /*插入到已有的表x中*/ |
<补充>
参数HDR的值:
HDR=Yes,这代表第一行是标题,不做为数据使用 ,如果用HDR=NO,则表示第一行不是标题,做为数据来使用。系统默认的是YES
参数Excel 8.0
对于Excel 97以上版本都用Excel 8.0
IMEX ( IMport EXport mode )设置
IMEX 有三种模式,各自引起的读写行为也不同,容後再述:
0 is Export mode
1 is Import mode
2 is Linked mode (full update capabilities)
我这里特别要说明的就是 IMEX 参数了,因为不同的模式代表著不同的读写行为:
当 IMEX=0 时为“汇出模式”,这个模式开启的 Excel 档案只能用来做“写入”用途。
当 IMEX=1 时为“汇入模式”,这个模式开启的 Excel 档案只能用来做“读取”用途。
当 IMEX=2 时为“连結模式”,这个模式开启的 Excel 档案可同时支援“读取”与“写入”用途。
意义如下:
0 —输出模式;
1—输入模式;
2—-链接模式(完全更新能力)
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
作者
相关推荐
-
Notre Dame对云端SQL Server性能基准的探索实践
确立SQL Server的性能基准,对于云端迁移来说是至关重要的第一步,一位来自于University of Notre Dame 的DBA表示,他正在试图通过数据库监控软件,找出SQL server的性能基准。
-
DBA必须掌握的数据库恢复管理技术
如果没有备份副本,数据库管理员就无法还原数据库,所以DBA在恢复之前倾向于考虑备份是合乎逻辑的。 但是,对我来说,这种逻辑一直是错误的。
-
DBA也要和领导抢饭碗?
数据库架构师Ziaul Mannan 认为,DBA有成为高管的潜在可能,而这种潜力在过去往往被忽视,他还将证明DBA技能到领导力的转变是可行的。
-
SQL Server 2005支持服务结束 升级何去何从
SQL Server 2005的支持就要结束了,就在2016年4月12日,SQL Server 2005的客户们应该升级了。