「10.Delphi数据库编程」1.Delphi数据库访问机制
mhr18 2024-12-25 10:36 15 浏览 0 评论
1.Delphi数据库访问机制
在 Delphi 中,设计和开发数据库应用系统时,对数据库进行访问的机制主要包括:ODBC、BDE、ADO 和 dbExpress、InterBase Express。其中,BDE 在 Delphi XE8 中已经明确被弃用,而 InterBase Express 不是一种独立于服务器的数据库引擎,而是一种用于访问特定数据库服务器的技术。所以,在这里我们主要对 ODBC、ADO 和 dbExpress 进行简要介绍。
1.1 ODBC
ODBC (Open Database Connectivity) 是 Microsoft、Sybase、Digital 公司为了解决不同数据库的访问于 1992 年共同制定的标准接口,提供独立于数据库的驱动支持。ODBC 使应用程序可以通过统一的接口访问各种数据库管理系统,而不必依赖于某个具体的数据库管理系统。
1.1.1 ODBC 体系结构
ODBC 体系结构由应用程序、驱动程序管理器、驱动程序和数据源等部件构成,如下图:
1.应用程序
应用程序执行并调用 ODBC 函数来提交 SQL 语句并接收 SQL 的执行结果。
2.驱动程序管理器
驱动程序管理器为应用程序装入驱动程序并执行:
- 使用 ODBC.INI 文件把数据源名映射为特定的驱动程序动态链接库
- ODBC 初始化调用
- 为驱动程序提供指向 ODBC 函数的入口指针
- 为 ODBC 调用提供参数确认和顺序确认
3.驱动程序
驱动程序为动态链接库(dll),实现 ODBC 函数调用并与数据源交互。
驱动程序的类型有单层和多层两种。
- 单层实现
驱动程序不单要执行 ODBC 调用,还要处理 SQL 语句。如对 xBase 文件的访问。
- 多层实现
驱动程序只处理 ODBC 调用,而 SQL 语句直接由数据源处理。如对 Oracle 的访问。
4.数据源
由数据库以及相关的操作系统、DBMS 和网络平台构成。
1.1.2 创建 ODBC 数据源
这里,我们以 PostgreSQL 数据库为例来说明创建 ODBC 数据源的方法。
1.安装 PostgreSQL ODBC 驱动程序
首先,在 PostgreSQL 官网上下载 ODBC 驱动程序。
下载地址:https://www.postgresql.org/ftp/odbc/versions/
如下图:
下载完成后,对 zip 文件进行解压缩,文件如下图:
双击 psqlodbc_x86.msi 文件进行安装。
2.创建 PostgreSQL ODBC 数据源
- 打开 ODBC 数据源管理器
选择 “开始” -> "Windows 管理工具" -> "ODBC 数据源",如下图:
DSN:是一个数据源的标志,便于应用程序访问数据,即,应用程序只需要知道相应的 DSN,而不会去关心数据库存储的位置和驱动程序等细节,直接通过 DSN 来访问数据库。DSN 包括三种类型:
- 用户 DSN - 只对设置它的用户可见
- 系统 DSN - 对机器上的所有用户均可见
- 文件 DSN - 将 DSN 配置信息保存到一个文件中
- 创建 ODBC 数据源
选择 “用户 DSN”,然后单击“添加”按钮,如下图:
在驱动程序列表中选择 “PostgreSQL Unicode”,单击“完成”按钮。如下图:
填写对应的数据库连接信息,单击“保存”按钮即可。其中 Data Source 即为 DSN 名称。
1.2 ADO
ADO(ActiveX Data Object)是 Microsoft 公司提供的数据库应用程序设计接口,是 Windows 平台数据处理的标准技术。ADO 技术的应用层界面是 OLE DB,使用 OLE DB 可以快速存取任何数据源,包括:关系型数据库与非关系型数据库、电子邮件与文件系统、文本与图形以及客户事务对象等。
ADO 的主要优点是易于使用、高速度、低内存和占用磁盘空间较少。ADO支持基于客户/服务器和 Web 应用程序的主要功能。
在 Delphi 中,提供了 dbGo 技术使得 Delphi 对 ADO 的支持更为稳定可靠。
1.3 dbExpress
dbExpress 是在 Kylix 中首先引进的一种极其快速、小巧、易发布的 SQL 数据库存储技术。由于它摆脱了传统的数据存取方式,完全摆脱了 BDE、ADO、ODBC 等存取数据方式,而且是 Kylix 中存取数据库的唯一方法,所以,它是一种真正跨平台的数据库存取技术,尤其适合开发多层(N-Tierd)应用。
dbExpress 为每一种其支持的数据库撰写具有统一接口的 dbExpress 驱动程序,所以,当发布 dbExpress 应用程序时,必须同时发布此驱动程序(一个DLL文件)。
为了跨平台设计,在 Delphi 中把 Kylix 使用的数据库存取技术引进来,提供了基于 dbExpress 的 VCL 组件。dbExpress 核心是提供快速获取数据库信息的驱动,支持跨平台开发。
轻量级和可移植性是 dbExpress 的两个主要特征。其主要特点:
1.dbExpress 只能访问 SQL 服务器。
2.dbExpress 只能执行 SQL 查询并且在单向指针上读取结果。对于单向数据库访问,能从一个记录移动到另一个记录,但不能返回数据集的前面的记录中,这是因为 dbExpress 没有缓存能力。为什么dbExpress数据处理比较快?答案是,它使用了单向数据集。它提供了一种高速、轻巧的存取数据库信息的技术,它能够向数据库服务器发送SQL指令,如果返回数据,它也能够获得访问这些数据的游标。但是,它只能处理单向、只读的游标、它不在内存中进行数据缓存,这样可以提高数据存取速度并使用最少的资源。
- 上一篇:Kettle之数据库连接方式
- 下一篇:五、如何使用Navicat模型
相关推荐
- Spring Boot3 连接 Redis 竟有这么多实用方式
-
各位互联网大厂的后端开发精英们,在日常开发中,想必大家都面临过系统性能优化的挑战。当系统数据量逐渐增大、并发请求不断增多时,如何提升系统的响应速度和稳定性,成为了我们必须攻克的难题。而Redis,这...
- 隧道 ssh -L 命令总结 和 windows端口转发配置
-
摘要:隧道ssh-L命令总结和windows端口转发配置关键词:隧道、ssh-L、端口转发、网络映射整体说明最近在项目中,因为内网的安全密级比较高,只能有一台机器连接内网数据库,推送...
- 火爆BOOS直聘的13个大厂Java社招面经(5年经验)助你狂拿offer
-
火爆BOOS直聘的13个大厂Java社招面经(5年经验)助你狂拿offer综上所述,面试遇到的所有问题,整理成了一份文档,希望大家能够喜欢!!Java面试题分享(Java中高级核心知识全面解析)一、J...
- 「第五期」游服务器一二三面 秋招 米哈游
-
一面下午2点,35分钟golang内存模型golang并发模型golanggc原理过程channel用途,原理redis数据结构,底层实现跳跃表查询插入复杂度进程,线程,协程kill原理除了kil...
- RMQ——支持合并和优先级的消息队列
-
业务背景在一个项目中需要实现一个功能,商品价格发生变化时将商品价格打印在商品主图上面,那么需要在价格发生变动的时候触发合成一张带价格的图片,每一次触发合图时计算价格都是获取当前最新的价格。上游价格变化...
- Redis 中的 zset 为什么要用跳跃表,而不是B+ Tree 呢?
-
Redis中的有序集合使用的是一种叫做跳跃表(SkipList)的数据结构来实现,而不是使用B+Tree。本文将介绍为什么Redis中使用跳跃表来实现有序集合,而不是B+Tree,并且探讨跳跃表...
- 一文让你彻底搞懂 WebSocket 的原理
-
作者:木木匠转发链接:https://juejin.im/post/5c693a4f51882561fb1db0ff一、概述上一篇文章《图文深入http三次握手核心问题【思维导图】》我们分析了简单的一...
- Redis与Java整合的最佳实践
-
Redis与Java整合的最佳实践在这个数字化时代,数据处理速度决定了企业的竞争力。Redis作为一款高性能的内存数据库,以其卓越的速度和丰富的数据结构,成为Java开发者的重要伙伴。本文将带你深入了...
- Docker与Redis:轻松部署和管理你的Redis实例
-
在高速发展的云计算时代,应用程序的部署和管理变得越来越复杂。面对各种操作系统、依赖库和环境差异,开发者常常陷入“在我机器上能跑”的泥潭。然而,容器化技术的兴起,尤其是Docker的普及,彻底改变了这一...
- Java开发中的缓存策略:让程序飞得更快
-
Java开发中的缓存策略:让程序飞得更快缓存是什么?首先,让我们来聊聊什么是缓存。简单来说,缓存是一种存储机制,它将数据保存在更快速的存储介质中,以便后续使用时能够更快地访问。比如,当你打开一个网页时...
- 国庆临近,字节后端开发3+4面,终于拿到秋招第一个offer
-
字节跳动,先面了data部门,3面技术面之后hr说需要实习转正,拒绝,之后另一个部门捞起,四面技术面,已oc分享面经,希望对大家有所帮助,秋招顺利在文末分享了我为金九银十准备的备战资源库,包含了源码笔...
- “快”就一个字!Redis凭什么能让你的APP快到飞起?
-
咱们今天就来聊一个字——“快”!在这个信息爆炸、耐心越来越稀缺的时代,谁不希望自己手机里的APP点一下“嗖”就打开,刷一下“唰”就更新?谁要是敢让咱用户盯着个小圈圈干等,那简直就是在“劝退”!而说到让...
- 双十一秒杀,为何总能抢到?Redis功不可没!
-
一年一度的双十一“剁手节”,那场面,简直比春运抢票还刺激!零点的钟声一敲响,亿万个手指头在屏幕上疯狂戳戳戳,眼睛瞪得像铜铃,就为了抢到那个心心念念的半价商品、限量版宝贝。你有没有发现一个奇怪的现象?明...
- 后端开发必看!为什么说Redis是天然的幂等性?
-
你在做后端开发的时候,有没有遇到过这样的困扰:高并发场景下,同一个操作重复执行多次,导致数据混乱、业务逻辑出错?别担心,很多同行都踩过这个坑。某电商平台就曾因订单创建接口在高并发时不具备幂等性,用户多...
- 开发一个app需要哪些技术和工具
-
APP开发需要一系列技术和工具的支持,以下是对这些技术的清晰归纳和分点表示:一、前端开发技术HTML用于构建页面结构。CSS用于样式设计和布局。JavaScript用于页面交互和逻辑处理。React...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)