ConFoo 2025

CollectionFind::bind

(No version information available, might only be in Git)

CollectionFind::bindBindet einen Wert an den Platzhalter einer Abfrage

Beschreibung

public mysql_xdevapi\CollectionFind::bind(array $placeholder_values): mysql_xdevapi\CollectionFind

Mit dieser Funktion kann ein Parameter an den Platzhalter in der Suchbedingung einer Suchanfrage gebunden werden. Der Platzhalter hat die Form :NAME, wobei ':' ein gewöhnliches Präfix ist, das vor jedem NAME stehen muss; NAME ist der eigentliche Name des Platzhalters. Um mehrere Elemente in der Suchbedingung ersetzen zu können, akzeptiert diese Funktion eine Liste von Platzhaltern.

Parameter-Liste

placeholder_values

Die Werte, die in der Suchbedingung ersetzt werden sollen; mehrere Werte sind zulässig und werden als Array mit "PLATZHALTER_NAME => PLATZHALTER_WERT" übergeben.

Rückgabewerte

Gibt ein CollectionFind-Objekt zurück. Alternativ kann es mit execute() verkettet werden, um ein Result-Objekt zu erhalten.

Beispiele

Beispiel #1 mysql_xdevapi\CollectionFind::bind()-Beispiel

<?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");
$create = $schema->createCollection("people");
$result = $create
->add('{"name": "Alfred", "age": 18, "job": "Butler"}')
->
execute();

// ...

$collection = $schema->getCollection("people");

$result = $collection
->find('job like :job and age > :age')
->
bind(['job' => 'Butler', 'age' => 16])
->
execute();

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

Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:

array(1) {
  [0]=>
  array(4) {
    ["_id"]=>
    string(28) "00005b6b536100000000000000cf"
    ["age"]=>
    int(18)
    ["job"]=>
    string(6) "Butler"
    ["name"]=>
    string(6) "Alfred"
  }
}
add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top