PHP Conference Japan 2024

Collection::find

(无版本信息可用,可能仅在 Git 中)

Collection::find搜索文档

描述

public mysql_xdevapi\Collection::find(string $search_condition = ?): mysql_xdevapi\CollectionFind

搜索数据库集合以查找文档或一组文档。找到的文档作为 CollectionFind 对象返回,以便进一步修改或从中获取结果。

参数

search_condition

虽然是可选的,但通常会定义一个条件以将结果限制为文档的子集。

多个元素可能构成条件,并且语法支持参数绑定。用作搜索条件的表达式必须是有效的 SQL 表达式。如果未提供搜索条件(字段为空),则假定为 find('true')。

返回值

一个 CollectionFind 对象,用于验证操作或获取找到的文档。

示例

示例 #1 mysql_xdevapi\Collection::find() 示例

<?php
$session
= mysql_xdevapi\getSession("mysqlx://user:password@localhost");

$session->sql("DROP DATABASE IF EXISTS addressbook")->execute();
$session->sql("CREATE DATABASE addressbook")->execute();

$schema = $session->getSchema("addressbook");
$collection = $schema->createCollection("people");

$collection->add('{"name": "Alfred", "age": 18, "job": "Butler"}')->execute();
$collection->add('{"name": "Bob", "age": 19, "job": "Swimmer"}')->execute();
$collection->add('{"name": "Fred", "age": 20, "job": "Construction"}')->execute();
$collection->add('{"name": "Wilma", "age": 21, "job": "Teacher"}')->execute();
$collection->add('{"name": "Suki", "age": 22, "job": "Teacher"}')->execute();

$find = $collection->find('job LIKE :job AND age > :age');
$result = $find
->bind(['job' => 'Teacher', 'age' => 20])
->
sort('age DESC')
->
limit(2)
->
execute();

print_r($result->fetchAll());
?>

以上示例将输出

Array
(
    [0] => Array
        (
            [_id] => 00005b6b536100000000000000a8
            [age] => 22
            [job] => Teacher
            [name] => Suki
        )
    [1] => Array
        (
            [_id] => 00005b6b536100000000000000a7
            [age] => 21
            [job] => Teacher
            [name] => Wilma
        )
)
添加注释

用户贡献的笔记

此页面没有用户贡献的笔记。
To Top