access函数_ACCESS中的DLookUp函数是如何运算的?
一、DLookUp函数介绍
1. DLookUp函数的用途:可以用于从指定集合(一个域)中获取符合条件的特定字段的值。
2. DLookUp函数的格式为:DLookUp( expr , domain , [criteria] )
其中:
expr 为字段名,或以字段名为基础的表达式字符串
domain 为记录集,可以是表名,也可以是不需要参数的选择(联合)查询
[criteria] 为取值范围,即数据的限定条件
3. DLookUp函数最终的运行结果为:domain记录集中,符合[criteria](范围)条件的,expr字段的值或基于expr字段值的表达式的运算结果。
例题:
表[学生]中有[学号]和[姓名]2个字段,其中[学号]为唯一主键,现要求获取表[学生]中[学号]为“XS001”的学生的[姓名]
解答:DLookUp("姓名","学生","学号= 'XS001' ")
二、DLookUp函数中的SQL查询逻辑
通过对DLookUp函数的运算逻辑进行分析,我们可以将DLookUp函数中的各个参数转化为SQL查询语句的构成部分。
其中:
expr 为SQL语句的 SELECT 部分,即指定的唯一字段
domain 为SQL语句的 FROM 部分,即选定的记录集(表来源)
[criteria] 为SQL语句的 WHERE 部分,即特定的数据范围
如此一来,上文中例题的DLookUp语句则可以理解为以下SQL语句:
SELECT 姓名 FROM 学生 WHERE 学号= "XS001"
当然,这是一种简单化的理解。假设表[学生]中的[学号]不是唯一主键的情况下呢?也就是说,可能存在[学号]相同的多个[姓名],但是DLookUp函数又必须只返回一个值,这种情况是如何处理的?
微软在Access中关于DLookUp函数的处理逻辑是返回第一个值。
因此,上述SQL语句可以进一步完善为:
SELECT TOP 1 姓名 FROM 学生 WHERE 学号= "XS001"
转化为通用格式,则是:
DLookUp(expr, domain, [criteria])
等价于
SELECT TOP 1 expr FROM domain WHERE [criteria]
三、将SELECT子查询转化为DLookUp运算结果的VBA逻辑
基于DLookUp函数中的SQL查询逻辑分析,我们可以逆向推导微软在将VBA封装进Access中时,关于DLookUp函数的运算过程如下:
Public Function DLookUp(ByVal expr As String, ByVal domain As String, ByVal criteria As String) As Variant
On Error GoTo DLookUp_err
Dim SQL As String, rst
SQL = "SELECT TOP 1 " & expr & " FROM " & domain & " WHERE " & criteria
Set rst = CurrentDb.OpenRecordset(SQL)
DLookUp = rst(expr)
Exit Function
DLookUp_err:
DLookUp = "#错误"
End Function
四、DLookUp函数的发散运用
在Access数据库中,微软通过VBA封装DLookUp函数为我们提供了获取SELECT子查询语句结果的快捷方式。
而在SQL Server等其他数据库中没有DLookUp函数可以使用,虽然可以使用SELECT子查询的方式来解决,如此一来在编写SQL查询时,SQL语句将会显得十分冗长和复杂。
但基于上文分析,我们已经掌握了将SELECT子查询语句转化为DLookUp函数运算结果逻辑,据此我们在VB.Net、C++、ASP、PHP等程序语言中,其实可以自行封装一个类DLookUp函数,在连接SQL Server(或其他数据库)时方便调用,简化SQL语句。
access函数_ACCESS中的DLookUp函数是如何运算的?相关推荐
- mysql mid函数_access 中关于MID函数的用法
展开全部 Mid 函数返回一个 Variant (String) 值,其中包含字符串中指定数量的字符. 若要62616964757a686964616fe78988e69d83313334336334 ...
- scala 函数中嵌套函数_Scala中的嵌套函数 用法和示例
scala 函数中嵌套函数 Scala中的嵌套函数 (Nested functions in Scala) A nested function is defined as a function whi ...
- oracle中转换函数,Oracle中的转换函数
Oracle中的转换函数有三个,分别为to_char(),to_date(),to_number() 1.to_char()的用法 格式化当前的日期时间 select sysdate,to_char( ...
- 自定义函数_Access中的WorkDate自定义函数
Access专家课堂两周年庆,视频课程.培训班.企业版等5~8折优惠,->点此了解详情 在Access中使用类似EXCEL中的WorkDate函数. 在Excel中有workdate函数,在AC ...
- python getattr函数_Python中的getattr()函数详解
在计算机编程中,自省是指这种能力:检查某些事物以确定它是什么.它知道什么以及它能做什么.自省向程序员提供了极大的灵活性和控制力. 自省(introspection),在计算机编程领域里,是指在运行时来 ...
- python函数def里面嵌套def_python 函数嵌套函数_Python中的嵌套函数
python 函数嵌套函数 A nested function is simply a function within another function, and is sometimes calle ...
- java中的string函数_java中string.trim()函数的作用实例及源码
trim()的作用:去掉字符串首尾的空格. public static void main(String arg[]){ String a=" hello world "; Str ...
- python里面map函数_python中的map()函数
先来看一下官方文档: map(function, iterable, ...) Apply function to every item of iterable and return a list o ...
- c++find函数_Excel中八大经典函数组合,帮你整理齐了
来源:Excel精英培训 作者:兰色幻想-赵志东 在Excel公式中,有些函数是独行侠,而有些函数经常是成对出现的,今天小编就带大家一起盘点Excel表格中八大经典函数组合. 1.IF + And 作 ...
最新文章
- docker实战部署Javaweb项目
- 【leetcode 简单】 第八十九题 赎金信
- linnux 流量控制模块tc_智能功率模块助力业界加速迈向基于碳化硅(SiC)的电动汽车...
- 李开复悔过:把运营微博当人生,把获取粉丝当游戏
- TFS突然链接不上(TF30063),并且MSN也连接不上,报主要端口的错误!
- Python编写简易木马程序
- 腾讯云Kafka海量服务自动化运营实践
- C#4.0 命名参数可选参数
- kubernetes之CI/CD工具jenkins第二篇,helm的使用
- Bootstrap 列偏移\列嵌套\列排序
- 家居有线网络布线方案(转)
- python爬虫实战——爬取猫眼电影TOP100并导入excel表
- Godot Label 节点
- 使用信号量机制解决家庭吃水果问题。
- 0x800704cf 共享打印机_0x800704cF,详细教您Win7访问共享时提示错误0x800704cf怎么办
- 2016 CCF-CSP 计算机职业资格认证考试 解题报告
- 企业应如何运用ERP系统的BOM表?
- 什么是项目管理,如何做好项目管理?
- 你的手指上有几个螺(斗)?指纹决定你的性格
- ARP 应用——检测IP地址冲突
热门文章
- 深入解析 C# 的 String.Create 方法
- Magicodes.Sms短信库的封装和集成
- 使用ASP.NET Core 3.x 构建 RESTful API - 1. 开始
- 动手造轮子:实现一个简单的依赖注入(一)
- .NET World——gPRC概览
- RabbitMQ 死信/死信队列
- 做「容量预估」可没有true和false
- Kafka基本知识整理
- dotnet core 微服务教程
- 自动将 NuGet 包的引用方式从 packages.config 升级为 PackageReference