为什么选择adodb而不用pdo

简介:

  如果在阅读文章之前你不知道adodb或者pdo,希望还是先去百度谷歌搜索下,了解下他们两个的优劣势,然后继续阅读下文。

  这篇文章我不会再继续讨论他们哪个更好,哪个效率更高,我只是从我工作中总结出一些问题,这些问题导致我放弃大家口口称赞的pdo,而选择adodb。

  adodb和pdo共同的一个优点就是:不管后端是什么数据库,存取数据的方式都是一样。也就是说,当我们的项目需要换个数据库时,不用去修改代码,只需修改下连接数据库的语句即可。而pdo还有一个最大的优点,它是用c语言实现,作为dll加入了php中,而adodb则是通过php去实现,相当于二次编译,执行的效率远远不及pdo。相信这也是很多php新手看到这句话后会立马选择pdo的原因吧。

  那为什么我不选择pdo,原因只有一个。因为pdo没有类似adodb的SelectLimit的函数,大家都知道mssq和mysql的分页语句是完全不相同的,mysql是用limit,mssql是用top+top,而mssql2005则又可以用ROW_NUMBER去实现。adodb的SelectLimit完美解决了这个问题,而pdo如果要解决这个问题,则需要自己写个方法,手动去判断不同的数据库,去写好不同的分页实现代码才能应付项目换数据库后只需修改数据库连接语句,不用修改代码的功能。

  当然,可能有些方面我没有想到或者没有找到资料,如果pdo有更好的方法可以解决我上面的疑问,希望告诉我。

  PS:不过总的来说,pdo的优势还是大于adodb,执行效率高,跨平台,而且又是未来php的标准连接数据库方式。如果你的项目确定一定以及肯定不会换数据库的话,我个人还是推荐使用pdo。

  PS2:之前也写过一个基于pdo的数据库操作类,有需要的童鞋可以看看,点击进入




   本文转自胡尐睿丶博客园博客,原文链接:http://www.cnblogs.com/hooray/archive/2011/03/21/1990034.html,如需转载请自行联系原作者


相关文章
|
存储 监控 Java
10分钟3个步骤集成使用SkyWalking
此时就非常推荐SkyWalking了,SkyWalking不仅仅是一款链路跟踪工具,还可以作为一个系统监控工具,还具有告警功能。使用简便、上手又快。真可谓快、准、狠。
10分钟3个步骤集成使用SkyWalking
|
消息中间件 存储 监控
【图解RabbitMQ-3】消息队列RabbitMQ介绍及核心流程
【图解RabbitMQ-3】消息队列RabbitMQ介绍及核心流程
741 0
|
域名解析 监控 网络协议
使用nginx配置一个ip对应多个域名
使用nginx配置一个ip对应多个域名
2111 1
使用nginx配置一个ip对应多个域名
|
JavaScript 前端开发 Python
用python执行js代码:PyExecJS库
文章讲述了如何使用PyExecJS库在Python环境中执行JavaScript代码,并提供了安装指南和示例代码。
708 1
用python执行js代码:PyExecJS库
|
SQL 关系型数据库 MySQL
MySQL 8.0:filesort 性能退化的问题分析
用户将 RDS MySQL 实例从 5.6 升级到 8.0 后,发现相同 SQL 的执行时间增长了十几倍。本文就该问题逐步展开排查,并最终定位根因。
|
10月前
|
人工智能 算法
大模型不会推理,为什么也能有思路?有人把原理搞明白了
大模型(LLMs)在推理任务上表现出与人类不同的问题解决思路。最新研究《Procedural Knowledge in Pretraining Drives Reasoning in Large Language Models》发现,大模型通过合成程序性知识来完成推理任务,而非简单检索答案。这为理解其推理能力提供了新视角,并指出了改进方向,如设计更有效的算法和使用更大规模数据。论文链接:https://arxiv.org/abs/2411.12580。
296 3
|
12月前
|
人工智能 自然语言处理 小程序
2023年关键字降本增“笑”,2024年的关键字会是什么呢?
《三潮来袭:2023年科技变革回顾与2024年展望》 2023年,IT行业经历了巨大变革。ChatGPT、AI和降本增效成为关键词。自然语言处理、边缘计算、量子计算等技术取得突破,推动行业发展。2024年,人工智能、云计算、全栈开发将继续引领趋势,移动营销、小程序应用和海外市场拓展将成为新的就业方向。企业将更注重稳定发展,减少试错,提高效率。 未来,持续学习和适应变化将是IT从业者的必备素质。随着全球互联网基础设施的普及,海外市场将为企业带来新的增长点。2024年的关键词可能是“智能化”、“全球化”和“高效化”。
202 5
|
前端开发 JavaScript UED
第五章(原理篇) 微前端技术之模块联邦与动态加载
第五章(原理篇) 微前端技术之模块联邦与动态加载
667 0
|
Linux 测试技术 Docker
Docker CE for CentOS 安装教程
Docker CE for CentOS 安装教程
402 1