>백엔드 개발 >PHP7 >php7에서 mongodb의 기본 사용법(자세한 코드 설명)

php7에서 mongodb의 기본 사용법(자세한 코드 설명)

藏色散人
藏色散人앞으로
2019-04-18 10:11:176158검색

팁: PHP의 mongodb 확장은 5.6부터 원래 mongo 확장을 포기했습니다. PHP7의 pecl 다운로드 주소: https://pecl.php.net/package/mongodb 또는 mongodb 공식 개발: https: //github.com/mongodb/mongo-php-library, git의 이 항목은 이전 mongo 쓰기 방법을 지원하지만 pecl의 mongodb는 이전 쓰기 방법을 지원하지 않습니다.

다음은 PHP7의 새로운 API에 대한 요약입니다.

One: CURD

1: Link

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

root user; 123: 비밀번호가 없으면 사용하지 마세요.

2: Query

<?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); 
}

추가 조건을 쿼리하려면 mongodb 기본 명령어의 두 번째 섹션을 참조하세요. Query

3:

<?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集合

4:

<?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集合

ordered 설정 추가.

1: 기본값은 true 이며, 데이터를 순차적으로 삽입하고 업데이트합니다. 오류가 발생하면 Mongo는 공식적으로 이를 직렬이라고 부릅니다.
2: false인 경우 mongo는 업데이트된 데이터를 동시에 삽입합니다. 중간에 오류가 발생하더라도 후속 작업에는 영향을 미치지 않습니다. Mongo는 이를 공식적으로 병렬이라고 부릅니다.

5: 삭제

<?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集合

delete 다르게 설정할 수도 있습니다. 제한을 통한 삭제 방법

$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 时,删除所有匹配数据,默认删除所有

6: 예외 잡기

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

지침: http://php.net/manual/zh/class.mongodb-driver-Exception-authenticationException.php

위 내용은 php7에서 mongodb의 기본 사용법(자세한 코드 설명)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제