PHP8 使用 MongoDB 的 PHP 库

2024-04-08 10:15 更新

在初始驱动程序设置之后,我们将继续解释如何获得 从MongoDB驱动和对应的用户空间库开始编写 我们的第一个项目。

使用 Composer 安装 PHP 库

我们仍然需要安装的最后一件事才能开始使用应用程序 本身,就是PHP库。

该库需要使用 » Composer(包管理器)进行安装 对于PHP。在各种平台上安装 Composer 的说明可能是 在其网站上找到。

通过运行以下命令安装库:

$ composer require mongodb/mongodb

它将输出类似于以下内容的内容:

./composer.json has been created
Loading composer repositories with package information
Updating dependencies (including require-dev)
  - Installing mongodb/mongodb (1.0.0)
    Downloading: 100%         

Writing lock file
Generating autoload files

Composer 将创建多个文件:、 和一个目录,该目录将 包含库和项目可能需要的任何其他依赖项。composer.jsoncomposer.lockvendor

使用 PHP 库

除了管理您的依赖项外,Composer 还将为您提供 使用自动加载器(用于这些依赖项的类)。确保它是 包含在脚本开头或应用程序的引导程序中 法典:

<?php
// This path should point to Composer's autoloader
require 'vendor/autoload.php';

完成此操作后,您现在可以使用 » 库文档中描述的任何功能。

如果您使用过其他语言的 MongoDB 驱动程序,则库的 API 应该看起来很熟悉。它包含一个用于连接到 MongoDB 的 客户端类,一个用于数据库级操作(例如命令、集合管理)的 » 数据库类, 以及用于集合级操作的  集合类(例如  CRUD 方法、索引管理)。

例如,以下是将文档插入演示数据库的 beers 集合的方法:

<?php
require 'vendor/autoload.php'; // include Composer's autoloader

$client = new MongoDB\Client("mongodb://localhost:27017");
$collection = $client->demo->beers;

$result = $collection->insertOne( [ 'name' => 'Hinterland', 'brewery' => 'BrewDog' ] );

echo "Inserted with Object ID '{$result->getInsertedId()}'";
?>

由于插入的文档不包含字段,因此 驱动程序将为 服务器用作 .此值也可用于 调用方通过方法返回的结果对象。_id_idinsertOne

插入后,您可以查询刚刚插入的数据。 为此,您可以使用返回可迭代对象的方法 光标:find

<?php
require 'vendor/autoload.php'; // include Composer's autoloader

$client = new MongoDB\Client("mongodb://localhost:27017");
$collection = $client->demo->beers;

$result = $collection->find( [ 'name' => 'Hinterland', 'brewery' => 'BrewDog' ] );

foreach ($result as $entry) {
    echo $entry['_id'], ': ', $entry['name'], "\n";
}
?>

虽然在示例中可能并不明显,但 BSON 文档和数组是 默认情况下,在库中未序列化为类型类。这些类确保 该值在序列化回 BSON 时保留其类型,这 避免了旧驱动程序中的警告,即数组可能会变成文档, 反之亦然。此外,这些类型类扩展了 ArrayObject 以增强可用性。您可以找到更多 有关如何在 PHP 变量之间进行序列化和反序列化的信息 BSON 由驱动程序和库通过读取持久数据规范进行处理。


以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号