PHP8 使用 MongoDB 的 PHP 库
在初始驱动程序设置之后,我们将继续解释如何获得 从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 由驱动程序和库通过读取持久数据规范进行处理。
更多建议: