mongodb 随机获取一条记录的方法
原理:
1.先查询表中的记录总数
2.随机获取偏移量为0~总记录数-1
3.查询时skip偏移量,再获取1条记录
因本人测试环境PHP已升级到7.0以上,mongodb扩展使用支持php7.0以上的扩展,很多方法与php5.6不同。因此代码必须在php7.0以上运行。如果是php5.6环境,需要修改代码才能运行。
代码如下:
function.php
<?php //连接mongodb functionconn($host,$user,$passwd){ $server='mongodb://'.$user.':'.$passwd.'@'.$host; try{ $conn=newMongoDB\Driver\Manager(); }catch(MongoDB\Driver\Exception\ConnectionException$e){ thrownewErrorException('Unabletoconnecttodbserver.Error:'.$e->getMessage(),31); } return$conn; } //插入数据 functionadd($conn,$dbname,$collname,$data,$index){ //创建索引 $cmd=array( 'createIndexes'=>$collname, 'indexes'=>array( array( 'name'=>'index', 'key'=>$index, 'ns'=>$dbname.'.'.$collname ) ) ); $command=newMongoDB\Driver\Command($cmd); $conn->executeCommand($dbname,$command); //插入数据 $bulk=newMongoDB\Driver\BulkWrite(); $inserted=0; if($data){ foreach($dataas$k=>$v){ $bulk->insert($v); } $result=$conn->executeBulkWrite($dbname.'.'.$collname,$bulk); $inserted=$result->getInsertedCount(); } return$inserted; } //获取总记录数 functiongetCount($conn,$dbname,$collname){ $cmd=array( 'count'=>$collname, 'query'=>array() ); $command=newMongoDB\Driver\Command($cmd); $result=$conn->executeCommand($dbname,$command); $response=current($result->toArray()); if($response->ok==1){ return$response->n; } return0; } //随机获取一条记录 functionrandOne($conn,$dbname,$collname){ //总记录数 $total=getCount($conn,$dbname,$collname); //随机偏移 $skip=mt_rand(0,$total-1); $filter=array(); $options=array('skip'=>$skip,'limit'=>1); $query=newMongoDB\Driver\Query($filter,$options); $cursor=$conn->executeQuery($dbname.'.'.$collname,$query); $result=array(); if($cursor){ foreach($cursoras$v){ $v=objectToArray($v); unset($v['_id']); $result[]=$v; } } return$result?$result[0]:$result; } //对象转为数组 functionobjectToArray($obj){ $arr=is_object($obj)?get_object_vars($obj):$obj; if(is_array($arr)){ returnarray_map(__FUNCTION__,$arr); }else{ return$arr; } } ?>
demo.php
<?php require('function.php'); //连接mongodb $conn=conn('localhost','testdb','root','123456'); //插入50条数据记录 $data=array(); //索引 $index=array('user'=>true); for($i=0;$i<50;$i++){ $data[]=array( 'user'=>'test_user_'.str_pad($i,4,'0',STR_PAD_LEFT) ); } $inserted=add($conn,'testdb','user',$data,$index); echo'成功插入'.$inserted.'条测试记录数<br><br>'; //随机获取一条记录,抽5次 echo'随机获取一条记录,抽5次<br>'; $result=array(); for($i=0;$i<5;$i++){ $result[]=randOne($conn,'testdb','user'); } echo'<pre>'; print_r($result); echo'</pre>'; ?>
输出:
成功插入50条测试记录数 随机获取一条记录,抽5次 Array ( [0]=>Array ( [user]=>test_user_0017 ) [1]=>Array ( [user]=>test_user_0026 ) [2]=>Array ( [user]=>test_user_0004 ) [3]=>Array ( [user]=>test_user_0043 ) [4]=>Array ( [user]=>test_user_0023 ) )
测试php代码,首先需要在mongodb创建testdb及创建用户和执行auth。方法如下:
usetestdb
db.createUser( { "user":"root", "pwd":"123456", "roles":[{"role":"readWrite","db":"testdb"}] } ) db.auth( { "user":"root", "pwd":"123456" } )
源码下载地址:点击查看
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!