首页 游戏 软件 资讯 排行榜 专题
首页
数据库
PEAR DB将数据库工作简化

PEAR DB将数据库工作简化

热心网友
36
转载
2026-04-30

有经验的PHPer应该对PEAR*都不会陌生,不过对新手来说,简单的练习PEAR应该不必派上用场,不过在开始接触复杂的编程时,PEAR对PHPer来说可以说是一个很有效的工具。

到底什么是PEAR?详细的答案都在pear.php.net上,这里就不多赘述了。不过,有一个工具值得重点介绍,它就是DB——一个构建在PEAR之上的数据库抽象层。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

PHP本身虽然提供了内置的数据库函数,但功能相对有限,而且在平台迁移时麻烦不小。比如,连接MySQL用的是mysql_connect(),而连接PostgreSQL则要用pg_connect()。如果你的程序只是小打小闹,把所有的mysql_[x]手动改成pg_[x]或许还扛得住。可一旦数据库操作层源码超过500行,这种改动简直就是一场噩梦!要是这些函数还散落在代码的各个角落,那修复起来就更恐怖了。

正因如此,一个跨平台的数据库接口抽象层就显得至关重要。它需要能接管大部分脏活累活,包括连接、查询、更新,最好还能提供调试功能。而PEAR DB,正是这样一个理想的工具。

它支持的数据平台相当广泛,包括dbase, Frontbase, InterBase, Informix, MiniSQL, MSSQL, MySQL, Oracle, ODBC, PostgreSQL, SQLite, Sybase。它完全可以作为PHP程序的整个数据库层,性能表现也相当理想(当然,纯粹论速度可能比直接调用mysql_query()稍慢一点,但在大型项目中,其可维护性和可移植性的优势就凸显出来了)。

PEAR DB的核心功能都封装在三个类里,用法并不复杂。下面就来逐一介绍。

1. DB类

DB类是PEAR DB的骨架,所有函数都以静态方式调用,这意味着你不需要实例化它,直接调用即可。

当配置好上述任意一种数据库后,第一步就是建立连接。这需要用到DB::connect()函数和一个DSN(数据源名称)字符串。DSN的格式如下:

sqltype://username:passwd@protocol+host/database?option=value

示例: $dsn = “mysql://username:passw0rD@localhost/mydb”

其中,Sqltype指数据库平台,具体的字符串可以去DSN文档页面查阅。

接下来,把DSN字符串传给DB::connect()

$conn = & DB::connect($dsn);

if(Pear::isError($conn)){
        die($conn->getMessage());
}

这里的$connDB::connect()返回的一个接口实例,后续它将扮演核心角色。注意下面一段代码,这里使用了PEAR::isError()来检查$conn是否是一个DB error对象。一旦连接出错,$conn会自动携带错误信息。getMessage()这个函数内置于DB error类,可以随时调用。

*通常情况下,PEAR会随PHP一起安装。如果需要单独安装,可以下载PHP完整压缩包,运行里面的do-pear.bat即可。(DB已经包含在PEAR安装包内,无需另外下载。)

2. DB_Common界面

刚才提到的$conn就是这个界面类型的实例。这个界面负责绝大部分的数据操作,包括查询、更新、插入等等。它包含大量功能强大的函数,这里先介绍几个关键的。

-- 查询示例
$sql = “SELECT * FROM blah”;
$conn->setFetchMode(DB_FETCHMODE_ASSOC);

$result = $conn->query($sql);

$row = $result->fetchRow();
print_r($row);

$conn->disconnect();

如果你熟悉PHP原生的数据库方法,对[x]_fetch_assoc应该不会陌生。没错,这里的意思大致相同。DB_Common的默认抓取模式是DB_FETCHMODE_ORDERED,效果类似于[x]_fetch_row。在上面的例子里,我们通过DB_Common::setFetchMode()将其改为DB_FETCHMODE_ASSOC,这样$result的抓取结果就会和[x]_fetch_assoc一样,以字段名作为数组索引。

这里的$result(属于DB_Result类)和mysql_query()返回的资源标识符作用类似,是PEAR DB里另一个重要的类型,稍后会介绍。如果需要获取一行数据,可以使用DB_Result::fetchRow(),它会返回一个包含一行数据的数组。

前面提到的PEAR::isError()同样可以用来检查$result是否有错误:

if(PEAR::isError($result)){
        die($result->getMessage());
}

方法和之前如出一辙,只是检查的对象从DB_Common实例换成了DB_Result实例。

DB_Common还提供了两个非常方便的方法,prepare()execute(),能让PHP轻松处理INSERT和UPDATE操作。这对组合可以让你高效地同时执行多个INSERT或UPDATE语句。prepare()预先载入要执行的SQL模板,而execute()则负责执行,并传入所需参数。看看下面的例子:

$conn->prepare(“INSERT INTO foo (fname, fage, flocation) VALUES (? , ? , ? )”);
$data = array(“foo”, 23, “earth”);
$conn->execute($stn, $data);

if(PEAR::isError($stn)){
        die($stn->getMessage());
}

$conn->freePrepared();

SQL中的“?”是占位符,$data数组里的数据会按顺序替换这些占位符。所有数据都会自动进行转义处理,execute()也能自动识别数字、字符串等数据类型。

那么,如果要插入多行数据呢?能不能简化操作?答案是肯定的。看看下面的例子,你就会发现DB是多么不可思议了:

$conn->prepare(“INSERT INTO foo (fname, fage, flocation) VALUES (? , ? , ? )”);
$data = array(
        array(“foo”, 23, “earth”),
        array(“faa”, 21, “moon”),
        array(“fee”, 25, “mars”),
        array(“fii”, 19, “Pluto”)
);
$conn->executeMultiple($stn, $data);

if(PEAR::isError($stn)){
        die($stn->getMessage());
}

$conn->freePrepared();

原本繁杂的操作,几行代码就搞定了,关键就在$data这个多维数组和DB_Common::executeMultiple()这个方法上。$stnexecute()executeMultiple()返回的结果,它有三种可能:第一是DB_Result对象,可以将查询结果转为实体;第二是预定义常量DB_OK,代表语句执行成功;第三就是DB_Error对象,后面的PEAR::isError()就是检查是否返回了这种错误对象。如果想用同一个DB_Common资源执行另一个查询,必须调用DB_Common::freePrepared()来清除之前prepare()载入的SQL模板。

DB_Common可以说是PEAR DB中最重要的操作界面,大部分和数据库的交互都在这里完成,功能十分强大。除了上面介绍的几个方法,它还有很多其他实用的方法,详细说明可以参考pear.php.net上的文档。

3. DB_Result

顾名思义,DB_ResultDB_Common执行查询后返回的数据集合。DB_Result本身是一个对象,内置了几个非常方便的方法。

-- fetchInto() 和 fetchRow()
这两个方法作用基本相同,唯一区别在于:前者将结果传递给一个引用参数($result->fetchInto(&$row));而后者直接返回结果($row = $result->fetchRow())。和PHP内置函数一样,fetchRow()每次返回一行数据。

-- numCols() 和 numRows()
这两个方法分别返回DB_Result中字段(列)和记录(行)的数量。

-- free()
DB_Result内的数据从内存中释放。

下面这个例子综合运用了以上几种方法:

$conn->setFetchMode(DB_FETCHMODE_ASSOC);
$result = $conn->query($sql);

echo “共找到 “.$result->numRows().” 条结果,包含 “.$result->numCols().” 个字段。”;

while( $row = $result->fetchRow()){
        echo $row[‘name’];
}

$result->free();

后记:
以上内容只是基础介绍,如果想深入了解,可以访问 https://pear.php.net/package/DB PHP PEAR的网页,里面有详细的文档可供参考。除了DB之外,PEAR网站上还提供了各式各样的数据库抽象层供免费下载,包括LDAP、ADODB,还有类似DB的MDB2,也是一个不错的选择。

来源:https://blog.csdn.net/iteye_9193/article/details/81654039
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

phpEnv如何修改PHP的post_max_size 解决表单提交数据限制
编程语言
phpEnv如何修改PHP的post_max_size 解决表单提交数据限制

phpEnv下修改post_max_size:一个参数引发的“血案”与完整解决方案 在phpEnv环境下调整post_max_size,绝不是改一个数字那么简单。它牵一发而动全身,必须联动修改upload_max_filesize和memory_limit,并且,改完后不重启服务,一切努力都等于零。

热心网友
04.30
如何在 Termux 中正确配置 Apache 以加载 PHP 模块
编程语言
如何在 Termux 中正确配置 Apache 以加载 PHP 模块

如何在 Termux 中正确配置 Apache 以加载 PHP 模块 在 Termux 中运行 Apache + PHP 时,因模块命名与 PHP 版本不匹配(如 PHP 8 x 实际提供 libphp so 而非 libphp7 so),导致 httpd: Cannot load not

热心网友
04.30
PEAR DB将数据库工作简化
数据库
PEAR DB将数据库工作简化

有经验的PHPer应该对PEAR*都不会陌生,不过对新手来说,简单的练习PEAR应该不必派上用场,不过在开始接触复杂的编程时,PEAR对PHPer来说可以说是一个很有效的工具。 到底什么是PEAR?详细的答案都在pear php net上,这里就不多赘述了。不过,有一个工具值得重点介绍,它就是DB—

热心网友
04.30
如何修改phpMyAdmin按钮的样式与悬停效果_CSS高级定制与主题深度修改指南
数据库
如何修改phpMyAdmin按钮的样式与悬停效果_CSS高级定制与主题深度修改指南

phpMyAdmin 按钮样式深度定制指南:避开那些“坑” phpMyAdmin 按钮 CSS 由 themes pmahomme css common css 和 components css 分层控制,新版通过 CSS 变量统一主题色;建议在 custom 下建独立主题覆盖 btn 等类,并

热心网友
04.30
phpEnv怎么开启Fileinfo扩展 phpEnv安装扩展方法
编程语言
phpEnv怎么开启Fileinfo扩展 phpEnv安装扩展方法

phpEnv 中无 fileinfo 选项属正常设计,需手动确认配置 在 Windows 下使用 phpEnv 时,如果发现界面里压根找不到开启 fileinfo 扩展的选项,先别急着怀疑软件有问题。这其实是它的设计逻辑:phpEnv 本质上是一个 PHP 版本切换和管理工具,它并不负责替你编译或安

热心网友
04.30

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

小米SU7车主引奥迪互动,新老品牌山脊赛道共赴热爱
娱乐
小米SU7车主引奥迪互动,新老品牌山脊赛道共赴热爱

2026年4月2日,一场始于订单的“双向奔赴” 汽车圈最近上演了一出颇有温度的品牌互动,起因是一张来自社交平台的购车订单。一位原奥迪车主公开晒出了小米SU7的订单截图,并向相关负责人致以问候。这原本只是一条个人动态,却没承想,引发了一连串超出预期的友好回应。 消息传出后,上汽奥迪的反应堪称迅速且巧妙

热心网友
04.30
特斯拉2026年Q1电动车产销双增,加速布局Robotaxi与人形机器人量产
娱乐
特斯拉2026年Q1电动车产销双增,加速布局Robotaxi与人形机器人量产

特斯拉2026年Q1财报解读:业绩稳健增长,自动驾驶与机器人战略加速落地 2026年第一季度,特斯拉再次向市场展示了其强劲的发展动能。在全球电动汽车市场,特斯拉产量成功突破40 8万辆,实现同比12 7%的稳健增长;同期交付量达到35 8万辆,同比增长6 5%。与此同时,特斯拉储能业务表现突出,总装

热心网友
04.30
我的世界愚人节更新移除仓库系统,地面直取物品引热议
娱乐
我的世界愚人节更新移除仓库系统,地面直取物品引热议

四月一日,沙盒游戏我的世界推出一次特别更新,引发广泛关注 话说回来,四月的第一天,经典沙盒游戏《我的世界》,就整了个“大活儿”。一项听起来颇有碘伏性的设计调整,在社区内炸开了锅:游戏直接移除了沿用已久的仓库系统,改为所有物品都能随手放在地面,想用的时候捡起来就行。 仓库功能向来是此类建造型游戏的核心

热心网友
04.30
某巨鲸从Kraken提取4,472枚ETH,当前持仓市值约2,000万美元
web3.0
某巨鲸从Kraken提取4,472枚ETH,当前持仓市值约2,000万美元

巨鲸再出手:千万美元级ETH悄然离场 市场总是静水深流。就在今天,链上数据捕捉到一笔值得玩味的动向。根据链上分析师Onchain Lens的监测,大约三小时前,一个地址尾号为“24d4”的巨鲸,从知名交易所Kraken一口气提取了4,472枚ETH。按当前市价估算,这笔资产价值接近一千万美元。 这可

热心网友
04.30
京东京造推黄金气囊磁吸支架:含1克99.99%黄金,售价1199元
娱乐
京东京造推黄金气囊磁吸支架:含1克99.99%黄金,售价1199元

京东京造再推黄金配件新品:磁吸支架以亲民价格亮相 关注京东京造的朋友一定还记得此前推出的黄金手机壳,因其独特设计与高纯度金材质引发了不少讨论。如今品牌再度升级,带来了一款更贴近日常使用的“轻量化”黄金配件——黄金气囊手机磁吸支架,进一步降低了黄金数码配件的入手门槛。 产品解析:含金量与设计亮点 这款

热心网友
04.30