亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mongodb 隨機(jī)獲取一條記錄的方法

 更新時(shí)間:2016年10月21日 10:01:27   投稿:lqh  
這篇文章主要介紹了 mongodb 隨機(jī)獲取一條記錄的方法的相關(guān)資料,需要的朋友可以參考下

原理:

1.先查詢表中的記錄總數(shù)

2.隨機(jī)獲取偏移量為0~總記錄數(shù)-1

3.查詢時(shí)skip偏移量,再獲取1條記錄

因本人測試環(huán)境PHP已升級到7.0以上,mongodb擴(kuò)展使用支持php7.0以上的擴(kuò)展,很多方法與php5.6不同。因此代碼必須在php7.0以上運(yùn)行。如果是php5.6環(huán)境,需要修改代碼才能運(yùn)行。

代碼如下:

function.php

<?php
// 連接mongodb
function conn($host, $user, $passwd){
  $server = 'mongodb://'.$user.':'.$passwd.'@'.$host;
  try{
    $conn = new MongoDB\Driver\Manager();
  } catch (MongoDB\Driver\Exception\ConnectionException $e){
    throw new ErrorException('Unable to connect to db server. Error:' . $e->getMessage(), 31);
  }
  return $conn;
}

// 插入數(shù)據(jù)
function add($conn, $dbname, $collname, $data, $index){

  // 創(chuàng)建索引
  $cmd = array(
    'createIndexes' => $collname,
    'indexes' => array(
      array(
        'name' => 'index',
        'key' => $index,
        'ns' => $dbname.'.'.$collname
      )
    )
  );
  $command = new MongoDB\Driver\Command($cmd);
  $conn->executeCommand($dbname, $command);

  // 插入數(shù)據(jù)
  $bulk = new MongoDB\Driver\BulkWrite();
  $inserted = 0;

  if($data){
    foreach($data as $k=>$v){
      $bulk->insert($v);
    }
    $result = $conn->executeBulkWrite($dbname.'.'.$collname, $bulk);
    $inserted = $result->getInsertedCount();
  }

  return $inserted;
}

// 獲取總記錄數(shù)
function getCount($conn, $dbname, $collname){
  $cmd = array(
    'count' => $collname,
    'query' => array()
  );
  $command = new MongoDB\Driver\Command($cmd);
  $result = $conn->executeCommand($dbname, $command);
  $response = current($result->toArray());
  if($response->ok==1){
    return $response->n;
  }
  return 0;
}

// 隨機(jī)獲取一條記錄
function randOne($conn, $dbname, $collname){

  // 總記錄數(shù)
  $total = getCount($conn, $dbname, $collname);

  // 隨機(jī)偏移
  $skip = mt_rand(0, $total-1);

  $filter = array();
  $options = array('skip'=>$skip, 'limit'=>1);
  $query = new MongoDB\Driver\Query($filter, $options);
  $cursor = $conn->executeQuery($dbname.'.'.$collname, $query);

  $result = array();
  if($cursor){
    foreach($cursor as $v){
      $v = objectToArray($v);
      unset($v['_id']);
      $result[] = $v;
    }
  }

  return $result? $result[0] : $result;
}

// 對象轉(zhuǎn)為數(shù)組
function objectToArray($obj){
  $arr = is_object($obj) ? get_object_vars($obj) : $obj;
  if(is_array($arr)){
    return array_map(__FUNCTION__, $arr);
  }else{
    return $arr;
  }
}
?>

demo.php

<?php
require('function.php');

// 連接mongodb
$conn = conn('localhost','testdb','root','123456');

// 插入50條數(shù)據(jù)記錄
$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.'條測試記錄數(shù)<br><br>';

// 隨機(jī)獲取一條記錄,抽5次
echo '隨機(jī)獲取一條記錄,抽5次<br>';
$result = array();
for($i=0; $i<5; $i++){
  $result[] = randOne($conn, 'testdb', 'user');
}

echo '<pre>';
print_r($result);
echo '</pre>';
?>

輸出:

成功插入50條測試記錄數(shù)

隨機(jī)獲取一條記錄,抽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創(chuàng)建testdb及創(chuàng)建用戶和執(zhí)行auth。方法如下:

use testdb

db.createUser( 
  { 
    "user":"root", 
    "pwd":"123456", 
    "roles":[{"role" : "readWrite", "db":"testdb"}] 
  } 
) 

db.auth( 
  { 
    "user":"root", 
    "pwd":"123456" 
  } 
) 

源碼下載地址:點(diǎn)擊查看

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • MongoDB憑什么躋身數(shù)據(jù)庫排行前五

    MongoDB憑什么躋身數(shù)據(jù)庫排行前五

    MongoDB以比去年同期超出65.96分的成績繼續(xù)雄踞榜單前五,這個(gè)增幅在全榜僅次于PostgreSQL的77.99,而其相對于4月份的6.10分的增長也是僅次于微軟SQL Server排名全榜第二
    2019-06-06
  • springboot整合mongodb?changestream的示例代碼

    springboot整合mongodb?changestream的示例代碼

    Chang?Stream(變更記錄流)?是指collection(數(shù)據(jù)庫集合)的變更事件流,應(yīng)用程序通過db.collection.watch()這樣的命令可以獲得被監(jiān)聽對象的實(shí)時(shí)變更,本文給大家介紹springboot整合mongodb?changestream的示例代碼,感興趣的朋友一起看看吧
    2022-02-02
  • MongoDB基礎(chǔ)命令以及操作示例詳解

    MongoDB基礎(chǔ)命令以及操作示例詳解

    Mongodb:是一種NoSQL數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關(guān)于MongoDB基礎(chǔ)命令以及操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-08-08
  • MongoDB中常用操作$addToSet、$pop和$rename

    MongoDB中常用操作$addToSet、$pop和$rename

    本文主要介紹了MongoDB中常用操作$addToSet、$pop和$rename,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-12-12
  • 使用zabbix監(jiān)控mongodb的方法

    使用zabbix監(jiān)控mongodb的方法

    MongoDB 是一個(gè)介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的。通過本文給大家介紹使用zabbix監(jiān)控mongodb的方法,需要的朋友參考下
    2016-02-02
  • mongoDB實(shí)現(xiàn)分頁的方法

    mongoDB實(shí)現(xiàn)分頁的方法

    這篇文章主要為大家詳細(xì)介紹了mongoDB實(shí)現(xiàn)分頁的兩種方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題

    Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題

    這篇文章主要介紹了Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Mongodb基本操作與Python連接mongodb并進(jìn)行基礎(chǔ)操作的方法

    Mongodb基本操作與Python連接mongodb并進(jìn)行基礎(chǔ)操作的方法

    mongodb是基于分布式文件存儲(chǔ)的nosql(非關(guān)系型)數(shù)據(jù)庫,本文分享了mongodb的基礎(chǔ)操作和Python連接并操作mongodb的基礎(chǔ)方法,基礎(chǔ)的不能再基礎(chǔ)了
    2018-09-09
  • MongoDB簡介 MongoDB五大特色

    MongoDB簡介 MongoDB五大特色

    這篇文章主要介紹了MongoDB簡介,MongoDB五大特色,本文講解了豐富的數(shù)據(jù)模型、容易擴(kuò)展、豐富的功能、高性能、簡便的管理等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • MongoDB可視化工具mongodb-compass

    MongoDB可視化工具mongodb-compass

    這篇文章介紹了MongoDB的可視化工具mongodb-compass,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06

最新評論