PHP - Manual: MongoCursor::slaveOkay
2025-10-24
(PECL mongo >=0.9.4)
MongoCursor::slaveOkay — Sets whether this query can be done on a secondary [deprecated]
This method is deprecated since version 1.5.0. Instead, please use MongoCursor::setReadPreference() and 读取首选项.
Calling this will make the driver route reads to secondaries if:
Note that you should use this function even if you do not use the automatic routing to secondaries. If you connect directly to a secondary in a replica set, you still need to call this function, which basically tells the database that you are aware that you might be getting older data and you're okay with that. If you do not call this, you'll get "not master" errors when you try to query.
This method will override the static class variable MongoCursor::$slaveOkay. It will also override Mongo::setSlaveOkay(), MongoDB::setSlaveOkay() and MongoCollection::setSlaveOkay().
okay
If it is okay to query the secondary.
Returns this cursor.
Throws MongoCursorException if this cursor has started iterating.
Example #1 MongoCursor::slaveOkay() example
<?php
MongoCursor::$slaveOkay = false;
// cannot query secondary
$cursor = $collection->find();
// can query secondary
$cursor = $collection->find()->slaveOkay();
MongoCursor::$slaveOkay = true;
// can query secondary
$cursor = $collection->find();
// cannot query secondary
$cursor = $collection->find()->slaveOkay(false);
?>
版本 | 说明 |
---|---|
1.5.0 | This method has been deprecated in favour of MongoCursor::setReadPreference() and 读取首选项. |
官方地址:https://www.php.net/manual/en/mongocursor.slaveokay.php