第六讲:VBA与ACCESS的ADO连接中,所涉及的对象

《VBA数据库解决方案》教程(10090845)是我推出的第二套教程,目前已经是第二版修订了。这套教程定位于中级,是学完字典后的另一个专题讲解。数据库是数据处理的利器,教程中详细介绍了利用ADO连接ACCDB和EXCEL的方法和实例操作,教程第一版的修订内容主要是完成所有程序文件的32位和64位OFFICE系统测试。

这套教程共两册,八十四讲,今后一段时间会给大家陆续推出修订后的教程内容。今日的内容是:第六讲:VBA与ACCESS的ADO连接中,所涉及的对象

984e94883c11d5d0c266e6f709bf1e24.jpeg

【分享成果,随喜正能量】身心是我们修行的代表,你是不是真修行,修得怎么样,一看你的相、看你的身体就知道了。你的功夫就在你脸上、就在你行为上,你怎么能骗人?。

第六讲 VBA与ACCESS的ADO连接中,所涉及的对象

大家好,今日继续讲解VBA数据库解决方案,在上几讲的内容中我们对数据库有了一个大概的了解,同时我们也清楚了连接数据库的不同方式,并对各个连接方式加以比较。今日的内容是深入的理解ADO与数据连接后的一些知识的准备.连接好数据后我们要进行的操作将更为具体。

在之前的讲解中,我一直在提ADO,ADO是DAO的后继产物。相比DAO,ADO扩展了DAO使用的层次对象模型,用较少的对象、更多的方法和事件来处理各种操作,简单易用,是当前数据库开发的主流技术。那么,ADO涉及到的对象都有哪些呢?今日我们就来深入的讲解.或许你之前看过数据库的一些文章,或者你是数据库的高手,但还是要理解或者了解到一些必要的知识.

4761fb87b95334c38685751e024b83fa.jpeg

1Connection对象

Connection对象是ADO对象模型中最高级的对象,这个对象实现了应用程序与数据源的连接。在上一讲和之前的内容中着重讲了如何实现的这个连接的问题.

2 Command对象

Command对象对象的主要作用是在VBA中通过SQL语句访问、查询数据库中的数据。

那么,什么是SQL 语句呢?这个词是英语Structured Query Language的首字母写法,翻译过来就是结构化查询语言,结构化查询语言是一种数据库查询和程序设计语言,可以用于存取数据以及查询、更新和管理关系数据库系统。

那么什么是结构化呢?所谓结构化,就是格式固定:

如:“select 表1.字段,表2.字段,表3.字段from 表名1,表名2,表名3...where 条件group by 字段order by 字段”.就要一段结构化的查询语句,非常易学,好记忆.

39b2c902e2d0b3864cfc9a3318c02caa.jpeg

3 Recordset对象

Recordset对象是这讲要讲的重点,他是存储访问表和查询对象返回的记录集合。使用该对象,可以浏览记录、修改记录、添加新的记录或者删除特定的记录。Recordset对象的功能是最常用、最重要的,我们在以后的代码中也是主要使用这个对象来完成我们的一些需求.

所有Recordset对象均使用记录(行)和字段(列)进行构造。具有其特定的属性和方法,使用ADO时,通过Recordset对象,利用这些属性和方法就可以编程处理数据库中的记录。

可对几乎所有数据进行操作。用这个记录集可执行的操作有:对表中的数据进行查询和统计,在表中添加、更新或删除记录。下面要将一下Recordset对象常见的属性、方法、和事件,(如果对属性、方法、事件着三个词语不理解的请赶快查看我的第一部作品《VBA代码解决方案》中的相关内容,我的作品的风格是一样的,最好能连续的学习)

3.1 Recordset对象一些常见的属性:

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

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

3.1.3 Index设置或返回 Recordset 对象的当前索引的名称。

3.1.4 RecordCount返回一个 Recordset 对象中的记录数目。

3.1.5 Source设置一个字符串值,或一个 Command 对象引用,或返回一个字符串值,此值可指示 Recordset 对象的数据源。

3.2 Recordset对象一些常见的方法

3.2.1 AddNew创建一条新记录。

3.2.2 Cancel撤销一次执行。

3.2.3 Close关闭一个 Recordset。

3.2.4 Delete删除一条记录或一组记录。

3.2.5 Find搜索一个 Recordset中满足指定某个条件的一条记录。

3.2.6Move在 Recordset对象中移动记录指针。

3.2.7 MoveFirst把记录指针移动到第一条记录。

3.2.8 MoveLast把记录指针移动到最后一条记录。

3.2.9 MoveNext把记录指针移动到下一条记录。

3.2.10 MovePrevious把记录指针移动到上一条记录。

3.2.11 NextRecordset通过执行一系列命令清除当前 Recordset 对象并返回下一个 Recordset。

3.2.12 Update保存所有对 Recordset 对象中的一条单一记录所做的更改。

3.2.13 Save把 Recordset 对象保存到 file 或 Stream 对象中。

3.2.14 UpdateBatch把所有,Recordset,中的更改存入数据库,请在批更新模式中使用

3.3 Recordset对象的事件

3.3.1 EndOfRecordset当试图移动到超过,Recordset,结尾的行时被触发

3.3.2 RecordChangeComplete一条记录更改之后被触发

7064e651ff366c9e916e75172760085e.jpeg

好了,今日就讲到这里,下一讲还将接着讲解Recordset 对象,会离我们的实际操作越来越近了,大家还是不要急,要弄懂必要的知识点,哪怕只是了解些,再慢慢的熟悉。数据库是数字化的产物,虽然他的问世时间还不是很长,最多也不过六、七十年的时间,但他的积累却是几何级数的,特别是上个世纪90年代之后,随着各种算法的实现,数据库的利用越来越多。

e3543935111b0701d4089b512785416c.jpeg

今日内容回向:

1 ADO 中的主要对象有哪些?

2 你是否清楚,操作一个数据库要有哪些必要的步骤呢?

本讲内容参考程序文件:VBA与数据库操作(第一册).xlsm

13a0394316ee3ef4e4f1df9931a80bb4.jpeg

我20多年的VBA实践经验,全部浓缩在下面的各个教程中:

3549217424fee69025e032da95ace79e.jpeg


db317dc1412e7f75d5a104feb8385615.jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/161342.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FreeRTOS笔记【一】 任务的创建(动态方法和静态方法)

一、任务创建和删除API函数 函数描述xTaskCreate()使用动态的方法创建一个任务xTaskCreateStatic()使用静态的方法创建一个任务xTaskCreateRestricted()创建一个使用MPU进行限制的任务,相关内存使用动态内存分配vTaskDelete()删除一个任务 二、动态创建任务 2.1 …

卷积与反卷积

文章目录 1 卷积1.1 卷积后的输出维度 2 反卷积2.1 来源2.2 原理2.3 使用2.3.1 padding2.3.2 strideoutput_padding 2.3 意义 1 卷积 1.1 卷积后的输出维度 设输入维度为i x i,卷积核大小为k x k,padding为p,strides为s,则输出维…

项目实战:新增@RequestMapping和@GetMapping和@PostMapping三个注解

1、RequestMapping package com.csdn.mymvc.annotation; import java.lang.annotation.*; Target(ElementType.TYPE) Retention(RetentionPolicy.RUNTIME) Inherited public interface RequestMapping {String value(); }2、PostMapping package com.csdn.mymvc.annotation; im…

NLP 模型中的偏差和公平性检测

一、说明 近年来,自然语言处理 (NLP) 模型广受欢迎,彻底改变了我们与文本数据交互和分析的方式。这些基于深度学习技术的模型在广泛的应用中表现出了卓越的能力,从聊天机器人和语言翻译到情感分析和文本生成。然而&…

JVM虚拟机:垃圾回收器组合参数设定

本文重点 前面的课程中我们介绍了目前JVM中主流的垃圾回收器,不同的回收器会有不同的组合,其中1.8版本的jdk中,默认使用的是Parallel ScavengeParallel Old,也就是说新生代使用Parallel Scavenge,然后老年代使用Paral…

Java Jar 包还不知道怎么反编译,赶紧看看这个 IDEA 插件!

前言 当我们使用 Java 开发时,经常会遇到一种情况:我们拿到了一个 JAR 文件,但是却没有源代码。这时候,我们就需要使用反编译工具来帮助我们还原出源代码。 反编译工具可以将编译后的 JAR 文件转换回可读的 Java 源代码。这样&a…

Go 如何实现并发

Go语言的并发机制是其强大和流行的一个关键特性之一。Go使用协程(goroutines)和通道(channels)来实现并发编程,这使得编写高效且可维护的并发代码变得相对容易。下面是Go的并发机制的详细介绍: 协程&#x…

【Qt之QtXlsx模块】安装及使用

1. 安装Perl,编译QtXlsx源码用 可以通过命令行进行查看是否已安装Perl。 下载及安装传送门:链接: https://blog.csdn.net/MrHHHHHH/article/details/134233707?spm1001.2014.3001.5502 1.1 未安装 命令:perl --version 显示以上是未安装…

阿里云安全恶意程序检测

阿里云安全恶意程序检测 赛题理解赛题介绍赛题说明数据说明评测指标 赛题分析数据特征解题思路 数据探索数据特征类型数据分布箱型图 变量取值分布缺失值异常值分析训练集的tid特征标签分布测试集数据探索同上 数据集联合分析file_id分析API分析 特征工程与基线模型构造特征与特…

CVE-2023-34040 Kafka 反序列化RCE

漏洞描述 Spring Kafka 是 Spring Framework 生态系统中的一个模块,用于简化在 Spring 应用程序中集成 Apache Kafka 的过程,记录 (record) 指 Kafka 消息中的一条记录。 受影响版本中默认未对记录配置 ErrorHandlingDeserializer,当用户将容…

Pycharm 对容器中的 Python 程序断点远程调试

pycharm如何连接远程服务器的docker容器有两种方法: 第一种:pycharm通过ssh连接已在运行中的docker容器 第二种:pycharm连接docker镜像,pycharm运行代码再自动创建容器 本文是第一种方法的教程,第二种请点击以上的链接…

Docker与微服务实战——基础篇

Docker与微服务实战——基础篇 第一章 Docker 简介1.1 docker 理念1.2 容器与虚拟机比较 第二章 Docker 安装2.1 前提说明2.2 Docker的基本组成2.2.1 镜像(image)2.2.2 容器(container)2.2.3 仓库(repository&#xff…