zoukankan      html  css  js  c++  java
  • TSQL用法四:OpenDataSource, OpenRowSet

    OPENDATASOURCE:

    不使用链接服务器的名称,而提供特殊的连接信息,并将其作为四部分对象名的一部分。

    OPENDATASOURCE ( provider_name, init_string )
    provider_name

    注册为用于访问数据源的 OLE DB 访问接口的 PROGID 的名称。provider_name 的数据类型为 char,无默认值。

    init_string

    连接字符串,该字符串将要传递给目标提供程序的 IDataInitialize 接口。提供程序字符串语法是以关键字值对为基础的,这些关键字值对由分号隔开,例如:“keyword1=value; keyword2=value”。
    例:将EXCEL表格读到库中
    USE NEWS
    select * into [Data] from OPENDATASOURCE('Microsoft.Jet.OLEDB.4.0','Excel 8.0;Database=绝对路径') ... [EXCEL表格名$]

    注意其中的HDR默认值为YES,也就是自动将EXCEL表中的第一行作为列名可以设置为NO
    select * into [Data] from OPENDATASOURCE('Microsoft.Jet.OLEDB.4.0','Excel 8.0;HDR=NO;Database=绝对路径') ... [EXCEL表格名$]

    将库中数据写到EXCEL表中
    USE NEWS
    INSERT INTO OPENDATASOURCE('Microsoft.Jet.OLEDB.4.0','Excel 8.0;Database=绝对路径'' )...[EXCEL表格名$] SELECT * FROM 库中表名


    OPENROWSET与上述功能一致,只不过,它可以查询,如:
    使用OpenRowSet(注意当HDR,IMEX设置不同时查询结果的差异)
    1. HDR=No; IMEX=0;
    SELECT *
    FROM OpenRowSet('MICROSOFT.JET.OLEDB.4.0', 'Excel 8.0; HDR=No; IMEX=0; DATABASE=c:\test.xls', WorkSheetName$)

    2. HDR=No; IMEX=1;
    SELECT *
    FROM OpenRowSet('MICROSOFT.JET.OLEDB.4.0', 'Excel 8.0; HDR=No; IMEX=1; DATABASE=c:\test.xls', WorkSheetName$)

    3. HDR=Yes; IMEX=0;
    SELECT *
    FROM OpenRowSet('MICROSOFT.JET.OLEDB.4.0', 'Excel 8.0; HDR=Yes; IMEX=0; DATABASE=c:\test.xls', WorkSheetName$)

    4. HDR=Yes; IMEX=1;
    SELECT *
    FROM OpenRowSet('MICROSOFT.JET.OLEDB.4.0', 'Excel 8.0; HDR=Yes; IMEX=1; DATABASE=c:\test.xls', WorkSheetName$)

  • 相关阅读:
    邻接矩阵有向图的介绍
    Oracle库Delete删除千万以上普通堆表数据的方法
    Oracle 11g静默安装软件+手工创建数据库
    Oracle基础维护02-表、主键、索引、表结构维护手册
    批处理:Windows主机通过FTP下载远程Linux主机上文件
    Vertica license导入最佳实践
    各类数据库问题描述模板
    Oracle同义词+dblink的实际应用
    Oracle数据逻辑迁移综合实战篇
    Greenplum 数据库安装部署(生产环境)
  • 原文地址:https://www.cnblogs.com/McJeremy/p/1328739.html
Copyright © 2011-2022 走看看