Maison > développement back-end > PHP7 > Utilisation de base de mongodb en php7 (explication détaillée du code)

Utilisation de base de mongodb en php7 (explication détaillée du code)

藏色散人
Libérer: 2023-02-17 12:18:01
avant
6151 Les gens l'ont consulté

Conseils : l'extension mongodb de PHP a abandonné l'extension mongo d'origine à partir de la version 5.6 Adresse de téléchargement PECL pour PHP7 : https://pecl.php net/package. /mongodb, ou choisissez le développement officiel de mongodb : https://github.com/mongodb/mongo-php-library Celui-ci sur git prend en charge la méthode d'écriture mongo précédente, mais le mongodb sur pecl ne prend pas en charge la méthode d'écriture précédente. .

Ce qui suit est un résumé de la nouvelle API de PHP7 :

1 : CURD

1 : Lien

<?php
//链接mongodb
$manager = new MongoDB\Driver\Manager(&#39;mongodb://root:123@10.10.10.104:27017&#39;);
Copier après la connexion

utilisateur root ; 123 : Mot de passe ; s'il n'y a pas de mot de passe, ne l'écrivez pas

2 : Requête

<?php

//链接mongodb
$manager = new MongoDB\Driver\Manager(&#39;mongodb://root:sjhc168@10.10.10.104:27017&#39;);

//查询
$filter =  [&#39;user_id&#39;=>[&#39;$gt&#39;=>0]]; //查询条件 user_id大于0
$options = [
   &#39;projection&#39; => [&#39;_id&#39; => 0], //不输出_id字段
   &#39;sort&#39; => [&#39;user_id&#39;=>-1] //根据user_id字段排序 1是升序,-1是降序
];
$query = new MongoDB\Driver\Query($filter, $options); //查询请求
$list = $manager->executeQuery(&#39;location.box&#39;,$query); // 执行查询 location数据库下的box集合


foreach ($list as $document) {
    print_r($document); 
}
Copier après la connexion

Pour interroger plus de conditions, veuillez vous référer à la deuxième section des commandes de base de mongodb, requête

3 : Ajouter

<?php

//链接mongodb
$manager = new MongoDB\Driver\Manager(&#39;mongodb://root:sjhc168@10.10.10.104:27017&#39;);

$bulk = new MongoDB\Driver\BulkWrite; //默认是有序的,串行执行
//$bulk = new MongoDB\Driver\BulkWrite([&#39;ordered&#39; => flase]);//如果要改成无序操作则加flase,并行执行
$bulk->insert([&#39;user_id&#39; => 2, &#39;real_name&#39;=>&#39;中国&#39;,]);
$bulk->insert([&#39;user_id&#39; => 3, &#39;real_name&#39;=>&#39;中国人&#39;,]);
$manager->executeBulkWrite(&#39;location.box&#39;, $bulk); //执行写入 location数据库下的box集合
Copier après la connexion

4 : Modifier

<?php

//链接mongodb
$manager = new MongoDB\Driver\Manager(&#39;mongodb://root:sjhc168@10.10.10.104:27017&#39;);

$bulk = new MongoDB\Driver\BulkWrite; //默认是有序的,串行执行
//$bulk = new MongoDB\Driver\BulkWrite([&#39;ordered&#39; => flase]);//如果要改成无序操作则加flase,并行执行
$bulk->update(
	[&#39;user_id&#39; => 2],
	[&#39;$set&#39;=>[&#39;real_name&#39;=>&#39;中国国&#39;]
]); 
//$set相当于mysql的 set,这里和mysql有两个不同的地方,
//1:字段不存在会添加一个字段;
//2:mongodb默认如果条件不成立,新增加数据,相当于insert


//如果条件不存在不新增加,可以通过设置upsert
//db.collectionName.update(query, obj, upsert, multi);

$bulk->update(
	[&#39;user_id&#39; => 5],
	[
		&#39;$set&#39;=>[&#39;fff&#39;=>&#39;中国国&#39;]
	],
	[&#39;multi&#39; => true, &#39;upsert&#39; => false] 
	//multi为true,则满足条件的全部修改,默认为true,如果改为false,则只修改满足条件的第一条
	//upsert为 treu:表示不存在就新增
);
$manager->executeBulkWrite(&#39;location.box&#39;, $bulk); //执行写入 location数据库下的box集合
Copier après la connexion

paramètre ordonné

1 : La valeur par défaut est vraie, insérez et mettez à jour les données dans l'ordre, en cas d'erreur se produit, arrêtez d'exécuter ce qui suit, mongo l'appelle officiellement chaîne OK.
2 : Si c'est faux, mongo insère les données mises à jour simultanément. Si une erreur se produit au milieu, cela n'affectera pas les opérations ultérieures. Mongo l'appelle officiellement parallèle

5 : Supprimer <🎜. >

<?php

//链接mongodb
$manager = new MongoDB\Driver\Manager(&#39;mongodb://root:sjhc168@10.10.10.104:27017&#39;);

$bulk = new MongoDB\Driver\BulkWrite; //默认是有序的,串行执行
//$bulk = new MongoDB\Driver\BulkWrite([&#39;ordered&#39; => flase]);//如果要改成无序操作则加flase,并行执行
$bulk->delete([&#39;user_id&#39;=>5]);//删除user_id为5的字段
$manager->executeBulkWrite(&#39;location.box&#39;, $bulk); //执行写入 location数据库下的box集合
Copier après la connexion
delete peut également définir différentes méthodes de suppression via la limite

$bulk->delete([&#39;user_id&#39; => 1], [&#39;limit&#39; => 1]);   // limit 为 1 时,删除第一条匹配数据
$bulk->delete([&#39;user_id&#39; => 2], [&#39;limit&#39; => 0]);   // limit 为 0 时,删除所有匹配数据,默认删除所有
Copier après la connexion

6 : Capturer les exceptions

MongoDB\Driver\Exception\AuthenticationException
MongoDB\Driver\Exception\BulkWriteException
MongoDB\Driver\Exception\ConnectionException
MongoDB\Driver\Exception\ConnectionTimeoutException
MongoDB\Driver\Exception\Exception //所有驱动程序异常的公共接口
MongoDB\Driver\Exception\ExecutionTimeoutException
MongoDB\Driver\Exception\InvalidArgumentException
MongoDB\Driver\Exception\LogicException
MongoDB\Driver\Exception\RuntimeException
MongoDB\Driver\Exception\SSLConnectionException
MongoDB\Driver\Exception\UnexpectedValueException
MongoDB\Driver\Exception\WriteException
Copier après la connexion
Instructions : http ://php .net/manual/zh/class.mongodb-driver-exception-authenticationexception.php

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:csdn.net
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal