Exemples
The central entry point to the X DevAPI is the mysql_xdevapi\getSession() function, which receives a URI to a MySQL 8.0 Server and returns a mysql_xdevap\Session object.
Exemple #1 Connecting to a MySQL Server
<?php
try {
$session = mysql_xdevapi\getSession("mysqlx://user:password@host");
} catch(Exception $e) {
die("Connection could not be established: " . $e->getMessage());
}
// ... use $session
?>
The session provides full access to the API. For a new MySQL Server installation, the first step is to create a database schema with a collection to store data:
Exemple #2 Creating a Schema and Collection on the MySQL Server
<?php
$schema = $session->createSchema("test");
$collection = $schema->createCollection("example");
?>
When storing data, typically json_encode() is used to encode the data into JSON, which can then be stored inside a collection.
The following example stores data into the collection we created earlier, and then retrieve parts of it again.
Exemple #3 Storing and Retrieving Data
<?php
$marco = [
"name" => "Marco",
"age" => 19,
"job" => "Programmer"
];
$mike = [
"name" => "Mike",
"age" => 39,
"job" => "Manager"
];
$schema = $session->getSchema("test");
$collection = $schema->getCollection("example");
$collection->add($marco, $mike)->execute();
var_dump($collection->find("name = 'Mike'")->execute()->fetchOne());
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
array(4) { ["_id"]=> string(28) "00005ad66aaf0000000000000003" ["age"]=> int(39) ["job"]=> string(7) "Manager" ["name"]=> string(4) "Mike" }
The example demonstrates that the MySQL Server adds an extra field named
_id
, which serves as primary key to the document.
The example also demonstrates that retrieved data is sorted alphabetically. That specific order comes from the efficient binary storage inside the MySQL server, but it should not be relied upon. Refer to the MySQL JSON datatype documentation for details.
Optionally use PHP's iterators fetch multiple documents:
Exemple #4 Fetching and Iterating Multiple Documents
<?php
$result = $collection->find()->execute();
foreach ($result as $doc) {
echo "${doc["name"]} is a ${doc["job"]}.\n";
}
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
Marco is a Programmer. Mike is a Manager.
Version en cache
03/01/2025 13:24:24 Cette version de la page est en cache (à la date du 03/01/2025 13:24:24) afin d'accélérer le traitement. Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la dernère version de la page.Document créé le 30/01/2003, dernière modification le 26/10/2018
Source du document imprimé : https://www.gaudry.be/php-rf-mysql-xdevapi.examples.html
L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.
Références
Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.