用SQL脚本读取Excel中的sheet数量及名称的方法代码

   2015-08-07 0
核心提示:这篇文章介绍了用SQL脚本读取Excel中的sheet数量及名称的方法代码,有需要的朋友可以参考一下

复制代码 代码如下:

-- Get table (worksheet) or column (field) listings from an excel spreadsheet  

-- 设置变量  
declare @linkedServerName sysname = 'TempExcelSpreadsheet' 
declare @excelFileUrl nvarchar(1000) = 'D:\text.xlsx' 
-- /SET  

-- 删除链接服务(如果它已经存在)  
if exists(select null from sys.servers where name = @linkedServerName) begin 
    exec sp_dropserver @server = @linkedServerName, @droplogins = 'droplogins' 
end 

-- 添加服务对象  
-- ACE 12.0 可以很好地工作为*.xls 和 *.xlsx, 你也可以用 Jet ,但是只能访问*.xls文件  
exec sp_addlinkedserver  
    @server = @linkedServerName,  
    @srvproduct = 'ACE 12.0',  
    @provider = 'Microsoft.ACE.OLEDB.12.0',  
    @datasrc = @excelFileUrl,  
    @provstr = 'Excel 12.0;HDR=Yes' 

-- 获取当前用户  
declare @suser_sname nvarchar(256) = suser_sname()  

-- 添加当前用户作为登陆这个链接服务  
exec sp_addlinkedsrvlogin  
    @rmtsrvname = @linkedServerName,  
    @useself = 'false',  
    @locallogin = @suser_sname,  
    @rmtuser = null,  
    @rmtpassword = null 

-- 返回 sheet 和 各个 sheet中的列  
exec sp_tables_ex @linkedServerName  
exec sp_columns_ex @linkedServerName  

--删除链接服务对象 

if exists(select null from sys.servers where name = @linkedServerName) begin 
    exec sp_dropserver @server = @linkedServerName, @droplogins = 'droplogins' 
end 

 
标签: SQL脚本 Excel sheet
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • mysql下如何执行sql脚本 执行SQL脚本
    1.编写sql脚本,假设内容如下:  create database dearabao;  use dearabao;  create table niuzi (name varchar(20));  保存脚本文件,假设我把它保存在F盘的hello world目录下,于是该文件的路径为:F:\hello world\niuzi.sql2.执行sql脚本,可以有2种方法: 
    02-10
  • Shell脚本中执行sql语句操作mysql shell脚本中
    对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本。本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考。对于脚本输出的结果美化,需要进一步完善和调整。以下为具体的示例及其方法。1、将SQL语
    02-10
  • Oracle 史上最全近百条Oracle DBA日常维护SQL脚
     史上最全近百条Oracle DBA日常维护SQL脚本指令  http://blog.itpub.net/30126024/viewspace-2057474/ ---具体SQL如下 查询碎片程度高(实际使用率小于30%)的表可以收缩的表条件为什么block100,因为一些很小的表,只有几行数据实际大小很小,但是block
    02-10
  • 本机不安装oracle服务器 和 客户端 使用pl/sql 及 powerdesigner反向工程生成不同数据库的sql脚本
    本机不安装oracle服务器 和 客户端 使用pl/sql
    本机为win7  安装数据库总是出错。一直未安装oracle 服务器及客户端。1、使用pl/sql ,网络上找到的方法:a、在安装oracle服务器的机器上搜索下列文件:oci.dll     ocijdbc10.dll     ociw32.dll     orannzsbb10.dll     oraocci10.dll  
    02-10
  • Oracle导入SQL脚本执行 scott 用户下的表删除了
    执行 .sql 文件时,应在 sqlplus  或 cmd 中执行,速度比plsql 中的command window 中书许多, scott 用户下的表删除了 可以执行如下 @D:\app\Administrator\product\11.2.0\dbhome_1\RDBMS\ADMIN\scott.sql 
    02-10
  • Oracle RAC阻塞排查SQL脚本
    Oracle RAC阻塞排查SQL脚本
     该使用到的sql脚本是参考别人技术文档转接过来用于日常工作中使用到的记录下。1,树形结构分级别显示会话之间的阻塞关系set lines 200 pages 100col tree for a30col event for a40select *  from (select a.inst_id, a.sid, a.serial#,         
    02-10
  • oracle下如何执行一个本地的.sql脚本文件
    分析:  我们通常在开发过程中会遇到很多程序修改或者批量修改数据的时候,会选择脚本的文件的形式通过命令来执行,那么怎么用plsql或者sqlplus执行sql脚本文件呢?说明:      如果说现在在c盘盘符下放置了一个我们需要执行的create.sql脚本文件,如果
    02-10
  • shell脚本中执行sql脚本并传递参数(mysql为例)
    shell脚本中执行sql脚本并传递参数(mysql为例)
    1、mysql脚本文件 t.sqlinsert into test.t values(@name,@age);exit2、shell脚本文件 a.sh  (为方便演示,与t.sql文件放在同一目录下)#!/bin/sh# fetch user parameters input by userread -p "please input name value : " nameread -p "please input name
    02-10
  • mysql远程执行sql脚本
    mysql远程执行sql脚本1.在命令行下mysql -h  远程服务器地址  –u用户名  –p密码 –D数据库sql脚本文件路径示例:mysql -h 192.168.1.1  -u test  -P 3306 -p123456   -Dtest/data/test/filename 2. 在命令行下(未连接数据库),输入mysql -h localho
    02-09
  • mysql导入sql文件,乱码,一个例子 mysql导入sq
    服务器centos,其他数据库都是utf8都正常能用 网页正常显示这次导入一个utf8格式数据库文件 结果网页上乱码在导出的sql文件中,注释部分有些语句也是被mysql考虑的。导出的sql文件,在服务器上导入后,文件本身是utf8但是还是乱码,此时检查sql文件首部是否有
    02-09
点击排行