sql >> Databáze >  >> NoSQL >> MongoDB

Jak správně zacházet s dotazy na stránkování pomocí mongodb a php?

Protože výsledek find()->limit()->skip() je Mongo_Cursor, nemusíte skutečný dotaz provádět dvakrát.

Mělo by fungovat také následující:

$skip = (int)($docs_per_page * ($page - 1));
$limit = $docs_per_page;

$query = array("loc" => array('$near' => array('lat' => $latitude, 'lon' => $longitute) ),
    "tags" => $tag, "seeking" => $this->session->userdata('gender'),
    "gender" => $this->session->userdata('seeking'));

$fields = array("username", "zipcode", "tags", "birth_date");
$cursor = $collection->find($query, $fields)->limit($limit)->skip($skip);
$total_documents = $cursor->count();
$data['result'] = $cursor;

btw nejprve jsem si špatně přečetl vaši otázku, myslel jsem, že nevíte o limit &skip.



  1. Spring -Mongodb ukládá/načítá výčty jako int ne řetězec

  2. Nejlepší postup MongoDB pro počítání souvisejících dokumentů

  3. Má Meteor odlišný dotaz na sbírky?

  4. Předkompilovaná aktiva Heroku se nezdařila