<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/mongodb.mongodb.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'class.mongodb-driver-readconcern.php',
    1 => 'MongoDB\\Driver\\ReadConcern',
    2 => 'Класс MongoDB\\Driver\\ReadConcern',
  ),
  'up' => 
  array (
    0 => 'mongodb.mongodb.php',
    1 => 'MongoDB\\Driver',
  ),
  'prev' => 
  array (
    0 => 'mongodb-driver-readpreference.gettagsets.php',
    1 => 'MongoDB\\Driver\\ReadPreference::getTagSets',
  ),
  'next' => 
  array (
    0 => 'mongodb-driver-readconcern.bsonserialize.php',
    1 => 'MongoDB\\Driver\\ReadConcern::bsonSerialize',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/mongodb/mongodb/driver/readconcern.xml',
  ),
  'history' => 
  array (
  ),
  'extra_header_links' => 
  array (
    'rel' => 'alternate',
    'href' => '/manual/en/feeds/class.mongodb-driver-readconcern.atom',
    'type' => 'application/atom+xml',
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="class.mongodb-driver-readconcern" class="reference">

 <h1 class="title">Класс MongoDB\Driver\ReadConcern</h1>
 

 <div class="partintro"><p class="verinfo">(mongodb &gt;=1.1.0)</p>

  
  <div class="section" id="mongodb-driver-readconcern.intro">
   <h2 class="title">Введение</h2>
   <p class="para">
    Класс <span class="classname"><strong class="classname">MongoDB\Driver\ReadConcern</strong></span> контролирует уровень
    изоляции для операций чтения для наборов реплик и сегментов наборов реплик.
    Эта опция требует БД MongoDB 3.2 или новее.
   </p>
  </div>
  

  <div class="section" id="mongodb-driver-readconcern.synopsis">
   <h2 class="title">Обзор класса</h2>

   
   <div class="classsynopsis">
    <span class="ooclass"><strong class="classname"></strong></span>

    
    <div class="classsynopsisinfo">
     <span class="modifier">final</span>
     <span class="ooclass">
      <span class="modifier">class</span> <strong class="classname">MongoDB\Driver\ReadConcern</strong>
     </span>

     <span class="oointerface"><span class="modifier">implements</span> 
       <a href="class.mongodb-bson-serializable.php" class="interfacename">MongoDB\BSON\Serializable</a></span><span class="oointerface">,  <a href="class.serializable.php" class="interfacename">Serializable</a></span> {</div>
    
    <div class="classsynopsisinfo classsynopsisinfo_comment">/* Константы */</div>
    <div class="fieldsynopsis">
     <span class="modifier">const</span>
     <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
      <var class="fieldsynopsis_varname"><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.linearizable"><var class="varname">AVAILABLE</var></a></var><span class="initializer"> = &quot;available&quot;</span>;</div>

    <div class="fieldsynopsis"><span class="modifier">const</span>
     <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
      <var class="fieldsynopsis_varname"><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.linearizable"><var class="varname">LINEARIZABLE</var></a></var><span class="initializer"> = &quot;linearizable&quot;</span>;</div>

    <div class="fieldsynopsis"><span class="modifier">const</span>
     <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
      <var class="fieldsynopsis_varname"><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.local"><var class="varname">LOCAL</var></a></var><span class="initializer"> = &quot;local&quot;</span>;</div>

    <div class="fieldsynopsis"><span class="modifier">const</span>
     <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
      <var class="fieldsynopsis_varname"><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.majority"><var class="varname">MAJORITY</var></a></var><span class="initializer"> = &quot;majority&quot;</span>;</div>

    <div class="fieldsynopsis"><span class="modifier">const</span>
     <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
      <var class="fieldsynopsis_varname"><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.snapshot"><var class="varname">SNAPSHOT</var></a></var><span class="initializer"> = &quot;snapshot&quot;</span>;</div>


    <div class="classsynopsisinfo classsynopsisinfo_comment">/* Методы */</div>
    <div class="methodsynopsis dc-description">
   <span class="modifier">final</span> <span class="modifier">public</span> <span class="methodname"><a href="mongodb-driver-readconcern.bsonserialize.php" class="methodname">bsonSerialize</a></span>(): <span class="type"><a href="class.stdclass.php" class="type stdClass">stdClass</a></span></div>
<div class="methodsynopsis dc-description"><span class="modifier">final</span> <span class="modifier">public</span> <span class="methodname"><a href="mongodb-driver-readconcern.construct.php" class="methodname">__construct</a></span>(<span class="methodparam"><span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.string.php" class="type string">string</a></span></span> <code class="parameter">$level</code><span class="initializer"> = <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong></span></span>)</div>
<div class="methodsynopsis dc-description"><span class="modifier">final</span> <span class="modifier">public</span> <span class="methodname"><a href="mongodb-driver-readconcern.getlevel.php" class="methodname">getLevel</a></span>(): <span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.string.php" class="type string">string</a></span></span></div>
<div class="methodsynopsis dc-description"><span class="modifier">final</span> <span class="modifier">public</span> <span class="methodname"><a href="mongodb-driver-readconcern.isdefault.php" class="methodname">isDefault</a></span>(): <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span></div>

   }</div>
   

  </div>

  
  <div class="section" id="mongodb-driver-readconcern.constants">
   <h2 class="title">Предопределённые константы</h2>
   <dl>

    
     <dt id="mongodb-driver-readconcern.constants.available"><strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.available">MongoDB\Driver\ReadConcern::AVAILABLE</a></code></strong></dt>
     <dd>
      <p class="para">
       По умолчанию для чтения на вторичных узлах, когда
       опции <code class="literal">afterClusterTime</code> и <code class="literal">level</code>
       не указали.
      </p>
      <p class="para">
       Запрос возвращает самые последние данные экземпляра. Не гарантирует,
       что данные были записаны большинству членов набора реплик
       (то есть могут быть откаты).
      </p>
      <p class="para">
       Для неохраняемых коллекций (включая коллекции в автономном
       развёртывании или развёртывании набора реплик), <code class="literal">&quot;local&quot;</code> и
       <code class="literal">&quot;available&quot;</code> гарантии чтения ведут себя одинаково.
      </p>
      <p class="para">
       Для сегментированного кластера <code class="literal">&quot;available&quot;</code> гарантии чтения
       обеспечивает большую терпимость для разделов, поскольку она не
       ожидает гарантий согласованности. Однако запрос с
       <code class="literal">&quot;available&quot;</code> гарантиями чтения может вернуть потерянные документы,
       если в сегменте выполняется миграция фрагментов, поскольку
       <code class="literal">&quot;available&quot;</code> гарантий чтения, в отличие от
       <code class="literal">&quot;local&quot;</code> гарантий чтения, не связывается
       с первичным сервером сегмента или серверами конфигурации для получения обновлённых метаданных.
      </p>
     </dd>
    

    
     <dt id="mongodb-driver-readconcern.constants.linearizable"><strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.linearizable">MongoDB\Driver\ReadConcern::LINEARIZABLE</a></code></strong></dt>
     <dd>
      <p class="para">
       Запрос возвращает данные, которые отражают все успешные записи, выпущенные с
       гарантиями записи <code class="literal">&quot;majority&quot;</code> <em>и</em>
       подтверждённые до начала операции чтения. Для наборов реплик,
       которые выполняются с параметром <code class="literal">writeConcernMajorityJournalDefault</code>,
       установленным в значение <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong>, линеаризуемые гарантии чтения возвращают данные, которые никогда
       не будут откатываться.
      </p>
      <p class="para">
       Если для <code class="literal">writeConcernMajorityJournalDefault</code> задано значение
       <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong>, MongoDB не будет ожидать, что <code class="literal">w: &quot;majority&quot;</code>
       записей будет устойчивым, прежде чем подтвердить записи. Таким образом, операции записи
       <code class="literal">&quot;majority&quot;</code> могут откатываться
       в случае потери члена набора реплик.
      </p>
      <p class="para">
       Вы можете указать линеаризуемые гарантии чтения для операций чтения только
       на основном сервере.
      </p>
      <p class="para">
       Линеаризуемые гарантии чтения применяются только в том случае, если в операциях чтения
       указан фильтр запроса, который однозначно идентифицирует один
       документ.
      </p>
      <div class="tip"><strong class="tip">Подсказка</strong>
       <p class="simpara">
        Всегда используйте <code class="literal">maxTimeMS</code> с линеаризуемыми гарантиями чтения,
        если большинство элементов, несущих данные, недоступно.
        <code class="literal">maxTimeMS</code> гарантирует, что операция не блокируется
        бесконечно, и вместо этого гарантирует, что операция возвращает ошибку, если
        проблема чтения не может быть выполнена.
       </p>
      </div>
      <p class="para">
       Для линеаризуемых гарантий чтения требуется MongoDB 3.4.
      </p>
     </dd>
    

    
     <dt id="mongodb-driver-readconcern.constants.local"><strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.local">MongoDB\Driver\ReadConcern::LOCAL</a></code></strong></dt>
     <dd>
      <p class="para">
       По умолчанию для чтения по первичному, если <code class="literal">level</code>
       не указан, и для чтения по вторичному, если <code class="literal">level</code>
       не указан, но задано <code class="literal">afterClusterTime</code>.
      </p>
      <p class="para">
       Запрос возвращает самые последние данные экземпляра. Не гарантирует,
       что данные были записаны большинству членов набора реплик
       (то есть могут быть откаты).
      </p>
     </dd>
    

    
     <dt id="mongodb-driver-readconcern.constants.majority"><strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.majority">MongoDB\Driver\ReadConcern::MAJORITY</a></code></strong></dt>
     <dd>
      <p class="para">
       Запрос возвращает самые последние данные экземпляра, которые были признаны
       записанными большинству членов в наборе реплик.
      </p>
      <p class="para">
       Чтобы использовать уровень гарантий чтения <code class="literal">&quot;majority&quot;</code>, наборы реплик
       должны использовать механизм хранения WiredTiger и протокол выбора версии 1.
      </p>
     </dd>
    

    
     <dt id="mongodb-driver-readconcern.constants.snapshot"><strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.snapshot">MongoDB\Driver\ReadConcern::SNAPSHOT</a></code></strong></dt>
     <dd>
      <p class="para">
       Гарантия чтения <code class="literal">&quot;snapshot&quot;</code> доступна для транзакций с несколькими документами, а начиная с MongoDB 5.0 также доступна для некоторых операций чтения не только для транзакций с несколькими документами.
      </p>
      <p class="para">
       Если транзакция не является частью причинно-согласованного сессии, после фиксации транзакции с проблемой записи <code class="literal">&quot;majority&quot;</code>,
       операции транзакции гарантированно прочитают из моментального снимка зафиксированных большинством данных.
      </p>
      <p class="para">
       Если транзакция является частью причинно-согласованной сессии, при фиксации транзакции с проблемой записи <code class="literal">&quot;majority&quot;</code>,
       операции транзакции гарантированно считывают из моментального снимка данные, подтверждённые большинством, что обеспечивает причинную согласованность с операций, непосредственно предшествующей началу транзакции.
      </p>
      <p class="para">
       Вне транзакций с несколькими документами, проблема чтения <code class="literal">&quot;snapshot&quot;</code> доступна на первичных и вторичных серверах
       для следующих операций чтения: <code class="literal">find</code>,
       <code class="literal">aggregate</code> и <code class="literal">distinct</code> (для необработанных коллекций).
       Все остальные команды чтения запрещают <code class="literal">&quot;snapshot&quot;</code>.
      </p>
     </dd>
    

   </dl>
  </div>
  

  <div class="section">
   <h2 class="title">Список изменений</h2>
   <p class="para">
    <table class="doctable informaltable">
     
      <thead>
       <tr>
        <th>Версия</th>
        <th>Описание</th>
       </tr>

      </thead>

      <tbody class="tbody">
       <tr>
        <td>PECL mongodb 1.11.0</td>
        <td>
         <p class="para">
          Добавлена константа <strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.snapshot">MongoDB\Driver\ReadConcern::SNAPSHOT</a></code></strong>.
         </p>
        </td>
       </tr>

       <tr>
        <td>PECL mongodb 1.7.0</td>
        <td>
         Реализует <span class="interfacename"><a href="class.serializable.php" class="interfacename">Serializable</a></span>.
        </td>
       </tr>

       <tr>
        <td>PECL mongodb 1.4.0</td>
        <td>
         <p class="para">
          Добавлена константа <strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.available">MongoDB\Driver\ReadConcern::AVAILABLE</a></code></strong>.
         </p>
        </td>
       </tr>

       <tr>
        <td>PECL mongodb 1.2.0</td>
        <td>
         <p class="para">
          Добавлена константа
          <strong><code><a href="class.mongodb-driver-readconcern.php#mongodb-driver-readconcern.constants.linearizable">MongoDB\Driver\ReadConcern::LINEARIZABLE</a></code></strong>.
         </p>
         <p class="para">
          Реализует <span class="interfacename"><a href="class.mongodb-bson-serializable.php" class="interfacename">MongoDB\BSON\Serializable</a></span>.
         </p>
        </td>
       </tr>

      </tbody>
     
    </table>

   </p>
  </div>

  <div class="section" id="mongodb-driver-readconcern.seealso">
   <h2 class="title">Смотрите также</h2>
   <ul class="simplelist">
    <li><a href="https://www.mongodb.com/docs/manual/reference/read-concern/" class="link external">&raquo;&nbsp;Справка по гарантиям чтения</a></li>
   </ul>
  </div>

 </div>

 



























<h2>Содержание</h2><ul class="chunklist chunklist_reference"><li><a href="mongodb-driver-readconcern.bsonserialize.php">MongoDB\Driver\ReadConcern::bsonSerialize</a> — Возвращает объект для сериализации BSON</li><li><a href="mongodb-driver-readconcern.construct.php">MongoDB\Driver\ReadConcern::__construct</a> — Создаёт новый ReadConcern</li><li><a href="mongodb-driver-readconcern.getlevel.php">MongoDB\Driver\ReadConcern::getLevel</a> — Возвращает опцию &quot;level&quot; ReadConcern</li><li><a href="mongodb-driver-readconcern.isdefault.php">MongoDB\Driver\ReadConcern::isDefault</a> — Проверяет, является ли гарантией чтения по умолчанию</li></ul>
</div>
<?php manual_footer($setup); ?>