百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

微软数据库访问接口(ODBC,OLEDB,ADO)

moboyou 2025-03-11 14:35 79 浏览

微软数据库访问接口(ODBC,OLEDB,ADO)

目录

  • 数据库访问接口发展历史
  • ODBC、OLEDB和ADO之间的关系
  • VB脚本下的数据库接口代码示例OLEDB连接ODBC连接执行SQL语句游标操作读取数据添加数据修改数据常用属性关闭连接
  • 在SQL Server中通过链接服务器查询OLE DB数据源
  • 在SQL Server中直接查询OLE DB数据源

微软数据库访问接口发展历史

ODBC历史

ODBC(Open Database Connectivity,开放数据库互连)。要了解ODBC是什么,先了解一下数据库连接的相关知识。在最开始连接数据库时,由于数据库种类繁多,各种数据库连接有不同的需求,这个时期,数据库连接主要依靠各种API函数来进行连接。在这种背景下,微软于1992年发表了ODBC, ODBC就是将这些API函数封装起来形成统一的接口。当SQL语句进入接口后,驱动器管理程序将它们送入对应的驱动器(driver),由驱动器将SQL语句送入各种不同的数据库。

OLE DB历史

OLE DB(Object Linking and Embedding, Database,对象链接嵌入数据库)是微软为以统一方式访问不同类型的数据存储设计的一种应用程序接口。OLE DB 是建立在 ODBC 功能之上的一个开放规范。ODBC 是为访问关系型数据库而专门开发的,OLE DB 则用于访问关系型和非关系型信息源。OLE DB可以通过ODBC连接到数据库,也可以直接连接到数据库,并且直接连接的访问速度更快。可以知道,只要支持ODBC的数据源是一定能够支持OLEDB的,但是反过来则不一定。

ADO历史

ADO(ActiveX Data Objects,ActiveX 数据对象)在1996年8月与OLE DB一起被发布,是在OLE DB上面创建的一个新的统一的数据访问的高层对象模型。ADO推出后顺利的取代了微软早期的数据访问对象层(包括RDO(Remote Data Objects)和DAO(Data Access Objects))。ADO将OLE DB的对象模型进一步简化,由数据库厂商开发满足OLE DB接口的数据提供者(data provider),而ADO本身则是与数据源无关(data source independent)的对象结构,这使得ADO通用性极好。

ODBC、OLEDB和ADO之间的关系

VB脚本下的数据库接口代码示例

OLEDB连接

标准安全模式(Standard Security)


1

2

3

4

dim conn, sCon

set conn=server.CreateObject("ADODB.Connection")

sCon="Provider=SQLOLEDB;Data Source=(local); Initial Catalog =dbname;User ID=sa;Password=123"

conn.open(sCon)


信任连接(Trusted connection)


1

2

3

4

dim conn, sCon

set conn=server.CreateObject("ADODB.Connection")

sCon="Provider=SQLOLEDB; Integrated Security=SSPI; Persist Security Info=False;Data Source=(local); Initial Catalog =dbname"

conn.open(sCon)


ODBC连接

通过系统数据源(System DSN)连接

先注册数据源:DSN。打开管理工具 -> 数据源(ODBC) -> 打开系统DSN选项卡 -> 单击添加按钮 -> 从列表中选择SQL Server,单击完成 -> 在名称中输入数据库名称,在你想连接的SQL Server服务器中输入(local)-> 按向导提示完成。


1

2

3

4

dim conn, sCon

set conn=server.CreateObject("ADODB.Connection")

sCon="DSN=注册名;Uid=sa;Pwd=123"

conn.open(sCon)


通过ODBC驱动程序连接


1

2

3

4

dim conn, sCon

set conn=server.CreateObject("ADODB.Connection")

sCon="Driver={SQL Server};Server=(local); Uid=sa;Pwd=123;Database=dbname"

conn.open(sCon)


执行SQL语句


1

2

3

4

Dim Sql, rs

Sql = "Select * From tablename"

Set rs = CreateObject("ADODB.Recordset")

rs.Open sSql,conn,2,3


rs.Open的参数如下:

  • Source:有效的命令对象、SQL语句、表名、存储过程调用、URL 或包含持久存储的记录集的文件或流对象的名称。
  • ActiveConnection:有效的连接对象变量,或包含ConnectionString参数的字符串。
  • CursorType:可选。一个CursorTypeEnum值,确定提供程序在打开记录集时应使用的游标类型。默认值为adOpenForwardOnly。
  • LockType:可选。LockTypeEnum值,用于确定提供程序在打开记录集 时应使用的(并发)类型。默认值为adLockReadOnly。


LockTypeEnum


常量

说明


adLockBatchOptimistic

4

执行多行批处理更新时使用这种类型。


adLockOptimistic

3

乐观锁定,仅在调用Update方法时锁定。


adLockPessimistic

2

悲观锁定,当记录集打开的时候将其锁定。


adLockReadOnly

1

默认,用来打开只读记录。


adLockUnspecified

-1

不指定锁的类型。



游标操作

1

2

3

4

rs.MoveFirst '把记录指针移动到第一条记录。

rs.MoveLast '把记录指针移动到最后一条记录。

rs.MoveNext '把记录指针移动到下一条记录。

rs.MovePrevious '把记录指针移动到上一条记录。

读取数据 

读取当前游标指示的行。 

1

2

dim value

value = rs("Field1")


添加数据

1

2

3

4

5

rs.AddNew

rs("Field1")=Value1

rs("Field2")=Value2

rs("Field3")=Value3

rs.update

修改数据

修改当前游标指示的行。

1

2

3

rs("Field1")=Value1

rs("Field2")=Value2

rs.update

常用属性

1

2

3

4

rs.Fields.Count '字段数量

rs.RecordCount '数据集行数

rs.BOF '如果当前的记录位置在第一条记录之前,则返回 true,否则返回 fasle。

rs.EOF '如果当前记录的位置在最后的记录之后,则返回 true,否则返回 fasle。

关闭连接

执行了select语句后Recordset会处在打开状态,其他执行其他SQL语句的Recordset未处在打开状态,不需要关闭。

在VBS中,离开对象作用域后会自动关闭。

1

2

3

4

rs.Close

set rs=Nothing

conn.Close

set conn=Nothing

在SQL Server中通过链接服务器查询OLE DB数据源

创建链接服务器

配置链接服务器使SQL Server数据库引擎能够访问SQL Server实例之外的OLE DB数据源。

在SQL Server Management Studio中,打开对象资源管理器,展开“服务器对象”,右键单击“链接服务器”,然后单击“新建链接服务器”。

在“常规”页中,“链接服务器”一栏中为链接服务器命名,并填入其他信息。

对链接数据库查询

在指定的链接服务器上执行传递查询。语法如下 :

OPENQUERY ( linked_server ,'query' )

参数:

  • linked_server:表示链接服务器名称的标识符。
  • ' query ':在链接服务器中执行的查询字符串。该字符串的最大长度为 8 KB。

OPENQUERY 可以在查询的 FROM 子句中引用,就好象它是一个表名

SELECT * FROM OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE name = ''NewTitle''');

在SQL Server中直接查询OLE DB数据源

通过OPENDATASOURCE()函数直接查询OLE DB数据源,语法如下:

OPENDATASOURCE ( 'provider_name', 'init_string' )

示例如下:

SELECT GroupName, Name, DepartmentID

FROM OPENDATASOURCE('MSOLEDBSQL', 'Server=Seattle1;Database=AdventureWorks2016;TrustServerCertificate=Yes;Trusted_Connection=Yes;').HumanResources.Department

ORDER BY GroupName, Name;

版权声明:本文原创发表于博客园,作者为星墨 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明, 且在文章页面明显位置给出原文连接,否则视为侵权。

相关推荐

Excel技巧:SHEETSNA函数一键提取所有工作表名称批量生产目录

首先介绍一下此函数:SHEETSNAME函数用于获取工作表的名称,有三个可选参数。语法:=SHEETSNAME([参照区域],[结果方向],[工作表范围])(参照区域,可选。给出参照,只返回参照单元格...

Excel HOUR函数:“小时”提取器_excel+hour函数提取器怎么用

一、函数概述HOUR函数是Excel中用于提取时间值小时部分的日期时间函数,返回0(12:00AM)到23(11:00PM)之间的整数。该函数在时间数据分析、考勤统计、日程安排等场景中应用广泛。语...

Filter+Search信息管理不再难|多条件|模糊查找|Excel函数应用

原创版权所有介绍一个信息管理系统,要求可以实现:多条件、模糊查找,手动输入的内容能去空格。先看效果,如下图动画演示这样的一个效果要怎样实现呢?本文所用函数有Filter和Search。先用filter...

FILTER函数介绍及经典用法12:FILTER+切片器的应用

EXCEL函数技巧:FILTER经典用法12。FILTER+切片器制作筛选按钮。FILTER的函数的经典用法12是用FILTER的函数和切片器制作一个筛选按钮。像左边的原始数据,右边想要制作一...

office办公应用网站推荐_office办公软件大全

以下是针对Office办公应用(Word/Excel/PPT等)的免费学习网站推荐,涵盖官方教程、综合平台及垂直领域资源,适合不同学习需求:一、官方权威资源1.微软Office官方培训...

WPS/Excel职场办公最常用的60个函数大全(含卡片),效率翻倍!

办公最常用的60个函数大全:从入门到精通,效率翻倍!在职场中,WPS/Excel几乎是每个人都离不开的工具,而函数则是其灵魂。掌握常用的函数,不仅能大幅提升工作效率,还能让你在数据处理、报表分析、自动...

收藏|查找神器Xlookup全集|一篇就够|Excel函数|图解教程

原创版权所有全程图解,方便阅读,内容比较多,请先收藏!Xlookup是Vlookup的升级函数,解决了Vlookup的所有缺点,可以完全取代Vlookup,学完本文后你将可以应对所有的查找难题,内容...

批量查询快递总耗时?用Excel这个公式,自动计算揽收到签收天数

批量查询快递总耗时?用Excel这个公式,自动计算揽收到签收天数在电商运营、物流对账等工作中,经常需要统计快递“揽收到签收”的耗时——比如判断某快递公司是否符合“3天内送达”的服务承...

Excel函数公式教程(490个实例详解)

Excel函数公式教程(490个实例详解)管理层的财务人员为什么那么厉害?就是因为他们精通excel技能!财务人员在日常工作中,经常会用到Excel财务函数公式,比如财务报表分析、工资核算、库存管理等...

Excel(WPS表格)Tocol函数应用技巧案例解读,建议收藏备用!

工作中,经常需要从多个单元格区域中提取唯一值,如体育赛事报名信息中提取唯一的参赛者信息等,此时如果复制粘贴然后去重,效率就会很低。如果能合理利用Tocol函数,将会极大地提高工作效率。一、功能及语法结...

Excel中的SCAN函数公式,把计算过程理清,你就会了

Excel新版本里面,除了出现非常好用的xlookup,Filter公式之外,还更新一批自定义函数,可以像写代码一样写公式其中SCAN函数公式,也非常强大,它是一个循环函数,今天来了解这个函数公式的计...

Excel(WPS表格)中多列去重就用Tocol+Unique组合函数,简单高效

在数据的分析和处理中,“去重”一直是绕不开的话题,如果单列去重,可以使用Unique函数完成,如果多列去重,如下图:从数据信息中可以看到,每位参赛者参加了多项运动,如果想知道去重后的参赛者有多少人,该...

Excel(WPS表格)函数Groupby,聚合统计,快速提高效率!

在前期的内容中,我们讲了很多的统计函数,如Sum系列、Average系列、Count系列、Rank系列等等……但如果用一个函数实现类似数据透视表的功能,就必须用Groupby函数,按指定字段进行聚合汇...

Excel新版本,IFS函数公式,太强大了!

我们举一个工作实例,现在需要计算业务员的奖励数据,右边是公司的奖励标准:在新版本的函数公式出来之前,我们需要使用IF函数公式来解决1、IF函数公式IF函数公式由三个参数组成,IF(判断条件,对的时候返...

Excel不用函数公式数据透视表,1秒完成多列项目汇总统计

如何将这里的多组数据进行汇总统计?每组数据当中一列是不同菜品,另一列就是该菜品的销售数量。如何进行汇总统计得到所有的菜品销售数量的求和、技术、平均、最大、最小值等数据?不用函数公式和数据透视表,一秒就...