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

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

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

微软数据库访问接口(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;

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

相关推荐

声学EI要完稿?十步速写法

【推荐会议】国际声学与振动会议(ICAV)会议号:CFP23112A截稿时间:2025年4月20日召开时间/地点:2025年8月15-17日·新加坡论文集上线:会后3个月提交EiComp...

结构力学!EI会议图表规范秘籍

推荐会议:国际结构与材料工程进展大会(ISME2026)会议编号:EI#73521截稿时间:2026年3月10日召开时间/地点:2026年8月15-17日·德国柏林论文集上线:会后4...

傅里叶级数物理意义的直观理解:利用傅里叶级数逼近方波信号

上篇文章将向大家介绍频谱的概念,对傅里叶级数、傅里叶积分、傅里叶变换进行了数学的推导,并解释了它们各自的物理意义。推导过程见我的上一篇文章:频谱分析——频谱概念(傅里叶变换、级数、积分及物理意义)如下...

通过对航空发动机整机振动进行分析,有何控制方法?

前言针对航空发动机整机振动问题的复杂性和多样性,以整机振动的振源分析为出发点,总结国内外关于转子系统故障、气流激振、轴承故障、齿轮故障和结构局部共振等引起的整机振动的研究情况。结合航空发动机整机结构动...

MATLIB中使用PCA

主成分分析PCA(PrincipalComponentsAnalysis),奇异值分解SVD(Singularvaluedecomposition)是两种常用的降维方法降维致力于解决三类问题:降维...

数据处理|软件:让科研更简单2

书接上回,继续介绍免费的数据处理软件。eGPS一款热图绘制专用软件,热图就是用颜色代表数字,让数据呈现更直观,对比更明显。优点:小巧方便,基本功能齐全,包括数据转换、聚类分析、颜色调整等等缺点:常见的...

电力系统常用的通讯协议及其在Speedgoat系统中的实现

在电力系统中,IEC61850协议、DNP3协议、ModbusTCP广泛应用于远程终端设备(RTU)、智能电子设备(IED)交互以及监控和数据采集(SCADA)系统。一、IEC61850协议IE...

电子工程师的常用仿真软件

不知道从事电子行业的工程师,有没有使用模拟仿真工具,仿真软件网上又有很多,初学者,可能只知道Multisim和Proteus。一般Multisim适合在学习模拟电路和电路分析原理课程时使用,便于理解电...

技术论文|异结构混沌系统的组合同步控制及电路实现

欢迎引用[1]李贤丽,马赛,樊争先,王壮,马文峥,于婷婷.异结构混沌系统的组合同步控制及电路实现[J].自动化与仪器仪表,2022,No.276(10):80-84.DOI:10.14016/j.cn...

现场︱某110KV主变事故过程仿真分析

三峡电力职业学院、河南省电力公司洛阳供电公司的研究人员李莉、任幼逢、徐金雄、王磊,在2016年第6期《电气技术》杂志上撰文,针对某110KV变电站主变差动保护跳闸事故,结合事故相关检测数据,通过MAT...

光伏发电系统篇:单级式并网系统实时仿真

在全球积极推动清洁能源转型的大背景下,光伏发电作为重要的可再生能源利用方式,得到了广泛关注和迅猛发展。目前常用的光伏并网及光伏电站主要拓扑结构有单级式和双级式。相较于传统的多级式系统,单级式光伏发电并...

光伏发电系统篇:三电平并网逆变器实时仿真

一、三电平并网逆变器在能源转型加速的当下,分布式能源接入电网需求大增。三电平并网逆变器凭借低谐波、高功率密度等优势,有效提升电能转换效率,于新能源并网发电中担当关键角色。常见的三电平电路拓扑结构包括二...

自制3.5KW大功率逆变器,很简单,看过这个电路原理就懂了

前言拿下8000元奖金的项目,是什么水平?本项目经过联合湖南科技大学光伏逆变以及电力电子研究生团队共同探讨方案。项目成本:1200元,获得奖金:8000元!参加赛事:立创开源硬件平台_星火计划·外包赛...

圈内分享:电容式加速度计接口电路非线性建模与仿真设计

摘要:非线性是Sigma-Delta(ΣΔ)加速度计系统的关键指标之一。基于一个五阶ΣΔ加速度计结构,分析了其主要的非线性模块,在MATLAB中建立了整体结构的行为级模型,并利用根轨迹法进行了稳...

基于Matlab/Simulink建立一种Thevenin/RC电池模块仿真模型

本文以锂电池数学模型为基础,在Matlab/Simulink的仿真系统中,建立了一种Thevenin/RC电池模块仿真模型,通过实际工况试验,测试精度在允许误差范围内,为电池SOC/SOH研究提供了极...