返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >PHP中DBA扩展的示例分析
  • 900
分享到

PHP中DBA扩展的示例分析

2023-06-15 10:06:32 900人浏览 八月长安
摘要

这篇文章主要介绍PHP中DBA扩展的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!php的DBA扩展学习今天我们讲的 DBA 并不是传统的数据库管理员那个 DBA ,而是一个 PHP 中的巴克利风格数据库的扩

这篇文章主要介绍PHP中DBA扩展的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

php的DBA扩展学习

今天我们讲的 DBA 并不是传统的数据库管理员那个 DBA ,而是一个 PHP 中的巴克利风格数据库的扩展。巴克利风格数据库其实就是我们常说的键值对形式的 K/V 数据库。就像我们平常用得非常多的 memcached 或者 redis 那样,只是一个键和一个值对应,不过 memcached 它们主要是存储在内存中,而 DBA 扩展则是将数据存储在文件中,就像一个简单的键值对形式的 sqlite 一样。

DBA 扩展所使用的数据库类型基本都是开源的,部署发布都很简单,就是一个 db 文件,所以说它和 SQLite 很相似。不过缺点就是,它会一次性将这个数据库文件加载到内存中,我们不能让这个数据库太大,否则就会撑爆内存。DBA 数据库都是和程序在一起的,所以它并没有网络相关的接口,我们一般也只会在代码本地使用这种数据库。

在安装的时候,我们需要在编译时增加 --enable-dba=shared 配置,然后还要增加一个 --enable-XXXX 配置,XXXX 指的就是我们要使用的巴克利风格数据库的类型,比较常见的有 dbm 、 ndbm 、 gdbm 、 db2 等等。同样的,操作系统也需要安装相关的这些软件,比如我们系统安装的就是 gdbm ,需要使用 yum install 来进行安装。

一个简单的例子

首先还是通过代码来看一下,我们的 DBA 数据库是如何使用的.

// 打开一个数据库文件$id = dba_open("/tmp/test.db", "n", "gdbm");//$id = dba_popen("/tmp/test1.db", "c", "gdbm");// 添加或替换一个内容dba_replace("key1", "This is an example!", $id);// 如果内容存在if(dba_exists("key1", $id)){    // 读取内容    echo dba_fetch("key1", $id), PHP_EOL;    // This is an example!}dba_close($id);

首先是使用 dba_open() 来打开一个数据库文件,第一个参数是数据库文件的路径,第二个参数是打开方式,包括 r 、 w 、 c 、 n ,r 表示只读,w 表示读写,c 表示创建加读写,n 表示如果没有就创建并可以读写。第三个参数就是指定的数据库类型,我们的系统中只安装了 gdbm 库,所以我们使用的就是 gdbm 作为参数。和 mysql 一样,我们也可以使用 dba_popen() 来打开一个数据文件的持久链接。

dba_replace() 函数则是添加或替换一条数据,如果数据不存在就新增加一条,如果存在了就替换对应 key 的值。第一个参数就是 key ,第二个参数就是数据的值 value 。

dba_exists() 就是判断指定的键是否存在,如果存在的话,我们在这个 if 里面就通过 dba_fetch() 获取键指定的数据。

dba_close() 就和其它数据操作句柄一样了,关闭数据库的连接句柄的。

添加、遍历、删除数据

在上面的例子中,我们使用的是 dba_replace() 来添加数据,其实正规的数据添加是有专门的函数的。

// 添加数据dba_insert("key2","This is key2!", $id);dba_insert("key3","This is key3!", $id);dba_insert("key4","This is key4!", $id);dba_insert("key5","This is key5!", $id);dba_insert("key6","This is key6!", $id);// 获取第一个 key$key = dba_firsTKEy($id);$handle_later = [];while ($key !== false) {    if (true) {        // 将 key 保存到数组中        $handle_later[] = $key;    }    // 获取下一个 key    $key = dba_nextkey($id);}// 遍历 key 数组,打印数据库中的全部内容foreach ($handle_later as $val) {    echo dba_fetch($val, $id), PHP_EOL;    dba_delete($val, $id); // 删除key对应的内容}// This is key4!// This is key2!// This is key3!// This is an example!// This is key5!// This is key6!

dba_insert() 就是插入数据,它不会去替换已经存在的键数据,如果是插入已经存在的键信息,就会返回 false 。

dba_firstkey() 用于获取第一个键,dba_nextkey() 用于获取下一个键,通过这两个函数,我们就可以获得整个数据库中的所有键信息,继而也就可以通过这些键来遍历整个数据库中的所有内容。

dba_delete() 就是根据键来删除一条数据了。

优化、同步数据库

即使是 Mysql ,在长时间使用后,我们也需要进行一些整理优化的工作,比如让 mysql 自动整理文件碎片,整理索引等,它使用的 SQL 语句是:optimize 表名 。同理,DBA 扩展也为我们提供了这样一个函数。

// 优化数据库var_dump(dba_optimize($id)); // bool(true)

另外,就像 mysql 的缓存一样,DBA 在操作数据的时候也会进行缓存,这时我们可以使用一个函数将缓存中的数据强制刷入硬盘文件中。

// 同步数据库var_dump(dba_sync($id)); // bool(true)

当前打开的数据库列表

我们可以通过一个函数来查看当前打开的数据连接有哪些,因为 DBA 是基于文件的简单数据库,所以我们可以在一段代码中打开多个数据连接。

// 获取当前打开的数据库列表var_dump(dba_list());// array(1) {//     [4]=>//     string(12) "/tmp/test.db"//   }

系统所支持的数据库类型

最后,我们再来看一个支持型的函数,它可以返回当前我们数据库所支持的数据库类型有哪些。

// 当前支持的数据库类型var_dump(dba_handlers(true));// array(5) {//     ["gdbm"]=>//     string(58) "GDBM version 1.18. 21/08/2018 (built May 11 2019 01:10:11)"//     ["cdb"]=>//     string(53) "0.75, $Id: 841505a20a8c9c8e35cac5b5dc3D5cf2fe917478 $"//     ["cdb_make"]=>//     string(53) "0.75, $Id: 95b1c2518144e0151afa6b2b8c7bf31bf1f037ed $"//     ["inifile"]=>//     string(52) "1.0, $Id: 42cb3bb7617b5744add2ab117b45b3a1e37e7175 $"//     ["flatfile"]=>//     string(52) "1.0, $Id: 410f3405266f41bafffc8993929b8830b761436b $"//   }var_dump(dba_handlers(false));// array(5) {//     [0]=>//     string(4) "gdbm"//     [1]=>//     string(3) "cdb"//     [2]=>//     string(8) "cdb_make"//     [3]=>//     string(7) "inifile"//     [4]=>//     string(8) "flatfile"//   }

dba_handlers() 有一个布尔类型的参数,通过代码我们可以看出这个参数的作用就是返回信息的详细程度

以上是“PHP中DBA扩展的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网PHP编程频道!

--结束END--

本文标题: PHP中DBA扩展的示例分析

本文链接: https://lsjlt.com/news/279948.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • PHP中DBA扩展的示例分析
    这篇文章主要介绍PHP中DBA扩展的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!PHP的DBA扩展学习今天我们讲的 DBA 并不是传统的数据库管理员那个 DBA ,而是一个 PHP 中的巴克利风格数据库的扩...
    99+
    2023-06-15
  • php安装扩展的示例分析
    这篇文章主要介绍php安装扩展的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!php安装扩展的步骤:1、解压文件“redis-3.1.1.tgz”;2、进入解压好的文件里面;3、phpize生成配置文件;4、...
    99+
    2023-06-15
  • php安装grpc扩展的示例分析
    这篇文章给大家分享的是有关php安装grpc扩展的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、在php.ini文件中添加grpc扩展配置:extension=grpc.sogit clon...
    99+
    2023-06-20
  • ES6中正则扩展的示例分析
    这篇文章将为大家详细讲解有关ES6中正则扩展的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:1. RegExp构造函数ES5中,RegExp构造函数的参...
    99+
    2024-04-02
  • CSS3的Regions扩展的示例分析
    本篇文章给大家分享的是有关CSS3的Regions扩展的示例分析,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。这是一个adobe的提议:css...
    99+
    2024-04-02
  • Jquery中Easyui验证扩展的示例分析
    这篇文章主要为大家展示了“Jquery中Easyui验证扩展的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Jquery中Easyui验证扩展的示例分析...
    99+
    2024-04-02
  • ES6中Array常用扩展的示例分析
    这篇文章主要介绍ES6中Array常用扩展的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!from方法将伪数组转换为数组let obj = { ...
    99+
    2024-04-02
  • redhat linux swap分区扩展的示例分析
    这篇文章主要为大家展示了“redhat linux swap分区扩展的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“redhat linux swap分区扩展的示例分析”这篇文章吧。re...
    99+
    2023-06-12
  • ES6中对象数值扩展的示例分析
    这篇文章主要介绍了ES6中对象数值扩展的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。对象数值扩展Object.is判断两个值是否完...
    99+
    2024-04-02
  • PHP中另一个高效缓存扩展Yac的示例分析
    这篇文章主要介绍了PHP中另一个高效缓存扩展Yac的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。PHP的另一个高效缓存扩展:Yac之前的文章中我们已经学习过一个 P...
    99+
    2023-06-15
  • PHP中命令行扩展Readline相关函数的示例分析
    小编给大家分享一下PHP中命令行扩展Readline相关函数的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!readline 扩展函数实现了访问 GNU ...
    99+
    2023-06-15
  • PHP代码加密和扩展解密的示例分析
    这篇文章主要介绍了PHP代码加密和扩展解密的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法...
    99+
    2023-06-14
  • PHP Hash信息摘要扩展框架的示例分析
    这篇文章主要介绍PHP Hash信息摘要扩展框架的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!PHP的Hash信息摘要扩展框架今天我们主要学习的是 PHP 中一些 Hash 散列加密相关的扩展函数的使用,而...
    99+
    2023-06-15
  • jQuery插件扩展操作的示例分析
    这篇文章将为大家详细讲解有关jQuery插件扩展操作的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:如下DEMO 展示了为dom扩展一个myshowHt...
    99+
    2024-04-02
  • Linux系统lvm卷扩展的示例分析
    这篇文章主要介绍了Linux系统lvm卷扩展的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。LVM是逻辑盘卷管理(Logical Volume Manager)的简称...
    99+
    2023-06-27
  • PHP自定义扩展之生命周期的示例分析
    这篇文章将为大家详细讲解有关PHP自定义扩展之生命周期的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php_request_startup这个阶段和php_module_startup差不多,都...
    99+
    2023-06-22
  • Python中Flask请求扩展与中间件的示例分析
    小编给大家分享一下Python中Flask请求扩展与中间件的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、请求扩展1.before_request作用: 类比django中间件中的process_request...
    99+
    2023-06-15
  • ES6正则表达式扩展的示例分析
    这篇文章主要为大家展示了“ES6正则表达式扩展的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ES6正则表达式扩展的示例分析”这篇文章吧。构造函数  在...
    99+
    2024-04-02
  • Spring自定义XML schema 扩展的示例分析
    小编给大家分享一下Spring自定义XML schema 扩展的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Spring整合dubbo的事例<be...
    99+
    2023-06-15
  • PHP应用发展的示例分析
    今天就跟大家聊聊有关PHP应用发展的示例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。PHP应用发展的速度是相当迅猛的。它的强大功能使它成为了许多程序员在开发网站时的***语言。...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作