当前位置:首页 > 话题广场 > 科技专区 > 互联网

vba如何通过odbc连接数据库 连接数据库

大家好,今日继续讲解VBA与数据库的第4讲内容:VBA如何与数据库建立连接。我的讲解从简单入手,逐渐将进入较为复杂的阶段,之前的内容主要以了解范畴的知识较多,将逐渐过渡到实际的操作。这讲内容仍需要读者以了解为侧重,但相关的知识点还是需要有一个清晰的轮廓。

VBA可以访问的数据库类型有Microsoft access、dBase、Microsoft SQLServer、Oracle 等,这给VBA的利用范围得到扩展。我们的讲解主要是VBA与Access数据库的连接方式,这种连接是大多数的应用。

一、利用ODBC方式连接Access数据库

利用这种方式连接数据库,必须先注册数据源DSN,目前,Windows提供32位和64位ODBC驱动程序,但在Access中,使用ODBC API访问数据库需要大量的VBA函数原型声明,操作繁琐,因此很少使用。这里就不再多说了。

二 通过OLEDB方式连接access数据库

OLE DB是用于访问数据的Microsoft系统级别的编程接口。它是一个规范,定义了一组组件接口规范,封装了各种数据库管理系统服务,是ADO的基本技术和ADO.NET的数据源

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

conn.open "Provider=Micro;Data Source="&<数据库名>&";Persist Security Info=False"

三 通过DAO方式连接Access数据库

DAO提供了一个访问数据库的对象模型,利用其中定义的一系列数据访问对象(如:Database、Recordset等),可以实现对数据库的各种操作,由于在创建数据库时系统并不自动引用DAO库,所以需要用户自行进行引用设置。具体设置步骤如下:

(1)在VBE工作环境中,选择"工具"菜单中的"引用"命令,打开"引用"对话框。

(2)在"可使用的引用"列表中勾选 "Microsoft DAO 3.6 Object Library" 如下图:

利用DAO 访问数据库 首先要创建对象变量,

Dim ws As Workspace

Dim db As Database

Dim rs As Recordset

Set ws = DBEngine.workspae(0) '打开默认工作区

Set db = ws.OpenDatabase("<数据库名>") ' 打开数据库

四 利用ADO方式连接Access数据库

ADO是基于组件的数据库编程接口。使用ADO可以方便地连接任何符合ODBC(开放式数据库连接)标准的数据库。ADO是DAO的后继产物。相比DAO,ADO扩展了DAO使用的层次对象模型,用较少的对象、更多的方法和事件来处理各种操作,简单易用,是当前数据库开发的主流技术。

1 引用ADO

(1)在VBE工作环境中,选择"工具"菜单中的"引用"命令,打开"引用"对话框。

(2)在"可使用的引用"列表中勾选 Microsoft ActiveX Data Object *.* Library,这里的*.*是指的时ADO的版本号,一般来说,应用程序或ActiveX控件都具有向下兼容性,所以我们尽可能选择比较新的版本.以确保程序在能识别旧版本Access的同时,也能识别较新版本的Access.

2.用CreateObject创建对象: Set Conn = CreateObjec)

创建了对象之后,下一步我们要做的就是打开数据库了.先看下面的代码,可以成功的打开数据库:

Set Conn = CreateObjec)

strPath = T & "\myda;

Conn.Open "Provider=Micro;Data Source=" & strPath

在之后的《VBA与数据库》的讲解中,主要利用的是ADO的连接,以后会逐渐的展开给大家慢慢的讲解。

数据库内容是VBA内的一块较为重要的部分,同时也是对于学习人员水平的一个提高,但是,如果我之前的内容没有弄懂的朋友,还是请先弄懂之前的内容,在《VBA代码解决方案》中,我讲解了147讲较为有代表的案例,可以覆盖大多数的知识点,基本掌握后再看数据库相关的操作,更会好些。

今日内容回向:

1 常见的几种连接数据库的方式是否有个大概的印象呢?

2 这几种常见的方式中那种是比较年轻的呢?

1.《vba如何通过odbc连接数据库 连接数据库》援引自互联网,旨在传递更多网络信息知识,仅代表作者本人观点,与本网站无关,侵删请联系页脚下方联系方式。

2.《vba如何通过odbc连接数据库 连接数据库》仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证。

3.文章转载时请保留本站内容来源地址,https://www.lu-xu.com/keji/3296628.html

上一篇

德罗索如何导弹、德罗索导弹怎么补充

[vba如何通过odbc连接数据库]力控ODBC连接mysql数据库!

  • [vba如何通过odbc连接数据库]力控ODBC连接mysql数据库!
  • [vba如何通过odbc连接数据库]力控ODBC连接mysql数据库!
  • [vba如何通过odbc连接数据库]力控ODBC连接mysql数据库!
.net如何连接数据库看这里!ADO.NET与ASP.NET MVC实现数据库连接及数据查询实例

.net如何连接数据库看这里!ADO.NET与ASP.NET MVC实现数据库连接及数据查询实例

.net如何连接数据库相关介绍,ASP。NET MVC4数据库操作实例 上一句话介绍了在结合MVC4和Pure框架的web设计过程中如何定义控制器、方法、型号、视图等。 并使用实例进行了简单说明。本文将在此基础上进一步说明如何使用M...

.net如何连接数据库?我来告诉你答案ADO.NET与ASP.NET MVC实现数据库连接及数据查询实例

.net如何连接数据库?我来告诉你答案ADO.NET与ASP.NET MVC实现数据库连接及数据查询实例

.net如何连接数据库相关介绍,ASP。NET MVC4数据库操作实例 上一句话介绍了在结合MVC4和Pure框架的web设计过程中如何定义控制器、方法、型号、视图等。 并使用实例进行了简单说明。本文将在此基础上进一步说明如何使用M...

.net如何连接数据库连接池?总结很全面速看!Java后端精选技术:Druid数据库连接池就是这么简单

.net如何连接数据库连接池?总结很全面速看!Java后端精选技术:Druid数据库连接池就是这么简单

.net如何连接数据库连接池相关介绍,前言 本章主要介绍Druid数据库连接池。为什么要学Druid数据库连接池?嗯? 我的知识储备数据库连接池有C3P0、DBCP两种,现在好像还不够用~当时学习C3P0的时候觉得这个数据库连接池很强大。...

.net如何连接mysql数据库?总结很全面速看!MySQL数据库驱动程序底层是如何连接数据库的?

.net如何连接mysql数据库?总结很全面速看!MySQL数据库驱动程序底层是如何连接数据库的?

.net如何连接mysql数据库相关介绍,指南:最近研究Calcite时发现使用Avatica框架构建数据库驱动程序,这让我很好奇MySQL的驱动程序基础是如何与MySQL数据库通信的。(威廉莎士比亚,美国作家)。 基本概念 在进行深入分析之...

.net如何连接数据库连接池看这里!Java后端精选技术:Druid数据库连接池就是这么简单

.net如何连接数据库连接池看这里!Java后端精选技术:Druid数据库连接池就是这么简单

.net如何连接数据库连接池相关介绍,前言 本章主要介绍Druid数据库连接池。为什么要学Druid数据库连接池?嗯? 我的知识储备数据库连接池有C3P0、DBCP两种,现在好像还不够用~当时学习C3P0的时候觉得这个数据库连接池很强大。...

.net如何连接数据库连接池?我来告诉你答案Java后端精选技术:Druid数据库连接池就是这么简单

.net如何连接数据库连接池?我来告诉你答案Java后端精选技术:Druid数据库连接池就是这么简单

.net如何连接数据库连接池相关介绍,前言 本章主要介绍Druid数据库连接池。为什么要学Druid数据库连接池?嗯? 我的知识储备数据库连接池有C3P0、DBCP两种,现在好像还不够用~当时学习C3P0的时候觉得这个数据库连接池很强大。...

关于.net如何连接数据库连接池,你需要知道这些手写数据库连接池你还不会?废话少说,直接上代码

关于.net如何连接数据库连接池,你需要知道这些手写数据库连接池你还不会?废话少说,直接上代码

.net如何连接数据库连接池相关介绍,前言 数据库连接池负责分配、管理和断开数据库连接,使应用程序能够重用现有数据库连接,而不是重新建立。断开空闲时间超过最大空闲时间的数据库连接,以防止数据库连接未断开而导致的数据库连接丢失。 这项技术能...