​一、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函数是如何运算的?相关推荐

  1. mysql mid函数_access 中关于MID函数的用法

    展开全部 Mid 函数返回一个 Variant (String) 值,其中包含字符串中指定数量的字符. 若要62616964757a686964616fe78988e69d83313334336334 ...

  2. scala 函数中嵌套函数_Scala中的嵌套函数 用法和示例

    scala 函数中嵌套函数 Scala中的嵌套函数 (Nested functions in Scala) A nested function is defined as a function whi ...

  3. oracle中转换函数,Oracle中的转换函数

    Oracle中的转换函数有三个,分别为to_char(),to_date(),to_number() 1.to_char()的用法 格式化当前的日期时间 select sysdate,to_char( ...

  4. 自定义函数_Access中的WorkDate自定义函数

    Access专家课堂两周年庆,视频课程.培训班.企业版等5~8折优惠,->点此了解详情 在Access中使用类似EXCEL中的WorkDate函数. 在Excel中有workdate函数,在AC ...

  5. python getattr函数_Python中的getattr()函数详解

    在计算机编程中,自省是指这种能力:检查某些事物以确定它是什么.它知道什么以及它能做什么.自省向程序员提供了极大的灵活性和控制力. 自省(introspection),在计算机编程领域里,是指在运行时来 ...

  6. python函数def里面嵌套def_python 函数嵌套函数_Python中的嵌套函数

    python 函数嵌套函数 A nested function is simply a function within another function, and is sometimes calle ...

  7. java中的string函数_java中string.trim()函数的作用实例及源码

    trim()的作用:去掉字符串首尾的空格. public static void main(String arg[]){ String a=" hello world "; Str ...

  8. python里面map函数_python中的map()函数

    先来看一下官方文档: map(function, iterable, ...) Apply function to every item of iterable and return a list o ...

  9. c++find函数_Excel中八大经典函数组合,帮你整理齐了

    来源:Excel精英培训 作者:兰色幻想-赵志东 在Excel公式中,有些函数是独行侠,而有些函数经常是成对出现的,今天小编就带大家一起盘点Excel表格中八大经典函数组合. 1.IF + And 作 ...

最新文章

  1. docker实战部署Javaweb项目
  2. 【leetcode 简单】 第八十九题 赎金信
  3. linnux 流量控制模块tc_智能功率模块助力业界加速迈向基于碳化硅(SiC)的电动汽车...
  4. 李开复悔过:把运营微博当人生,把获取粉丝当游戏
  5. TFS突然链接不上(TF30063),并且MSN也连接不上,报主要端口的错误!
  6. Python编写简易木马程序
  7. 腾讯云Kafka海量服务自动化运营实践
  8. C#4.0 命名参数可选参数
  9. kubernetes之CI/CD工具jenkins第二篇,helm的使用
  10. Bootstrap 列偏移\列嵌套\列排序
  11. 家居有线网络布线方案(转)
  12. python爬虫实战——爬取猫眼电影TOP100并导入excel表
  13. Godot Label 节点
  14. 使用信号量机制解决家庭吃水果问题。
  15. 0x800704cf 共享打印机_0x800704cF,详细教您Win7访问共享时提示错误0x800704cf怎么办
  16. 2016 CCF-CSP 计算机职业资格认证考试 解题报告
  17. 企业应如何运用ERP系统的BOM表?
  18. 什么是项目管理,如何做好项目管理?
  19. 你的手指上有几个螺(斗)?指纹决定你的性格
  20. ARP 应用——检测IP地址冲突

热门文章

  1. 深入解析 C# 的 String.Create 方法
  2. Magicodes.Sms短信库的封装和集成
  3. 使用ASP.NET Core 3.x 构建 RESTful API - 1. 开始
  4. 动手造轮子:实现一个简单的依赖注入(一)
  5. .NET World——gPRC概览
  6. RabbitMQ 死信/死信队列
  7. 做「容量预估」可没有true和false
  8. Kafka基本知识整理
  9. dotnet core 微服务教程
  10. 自动将 NuGet 包的引用方式从 packages.config 升级为 PackageReference