<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/class.pdo.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'pdo.setattribute.php',
    1 => 'PDO::setAttribute',
    2 => 'Устанавливает атрибут',
  ),
  'up' => 
  array (
    0 => 'class.pdo.php',
    1 => 'PDO',
  ),
  'prev' => 
  array (
    0 => 'pdo.rollback.php',
    1 => 'PDO::rollBack',
  ),
  'next' => 
  array (
    0 => 'class.pdostatement.php',
    1 => 'PDOStatement',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/pdo/pdo/setattribute.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="pdo.setattribute" class="refentry">
 <div class="refnamediv">
  <h1 class="refname">PDO::setAttribute</h1>
  <p class="verinfo">(PHP 5 &gt;= 5.1.0, PHP 7, PHP 8, PECL pdo &gt;= 0.1.0)</p><p class="refpurpose"><span class="refname">PDO::setAttribute</span> &mdash; <span class="dc-title">
   Устанавливает атрибут
  </span></p>

 </div>
 <div class="refsect1 description" id="refsect1-pdo.setattribute-description">
  <h3 class="title">Описание</h3>
  <div class="methodsynopsis dc-description">
   <span class="modifier">public</span> <span class="methodname"><strong>PDO::setAttribute</strong></span>(<span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$attribute</code></span>, <span class="methodparam"><span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span> <code class="parameter">$value</code></span>): <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span></div>


  <p class="para rdfs-comment">
   Метод устанавливает атрибут в дескрипторе базы данных. Отдельные общие атрибуты приводит следующий параграф;
   отдельные драйверы иногда используют дополнительные атрибуты, характерные для драйвера.
   Обратите внимание, что атрибуты конкретного драйвера <em>нельзя</em>
   указывать с другими драйверами.

   <dl>
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-case">PDO::ATTR_CASE</a></code></strong></dt>
     <dd>
      <p class="para">
       Принудительное приведение названия столбцов к конкретному регистру.
       Принимает значение из следующего списка:
      </p>
      <dl>
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.case-lower">PDO::CASE_LOWER</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Принудительное приведение названий столбцов к нижнему регистру.
         </span>
        </dd>
       
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.case-natural">PDO::CASE_NATURAL</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Оставить названия столбцов в том виде, в котором их возвращает драйвер базы данных.
         </span>
        </dd>
       
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.case-upper">PDO::CASE_UPPER</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Принудительное приведение названий столбцов к верхнему регистру.
         </span>
        </dd>
       
      </dl>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-errmode">PDO::ATTR_ERRMODE</a></code></strong></dt>
     <dd>
      <p class="para">
       Режим сообщения об ошибках модуля PDO.
       Принимает значение из следующего списка:
      </p>
      <dl>
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.errmode-silent">PDO::ERRMODE_SILENT</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Устанавливает только коды ошибок.
         </span>
        </dd>
       
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.errmode-warning">PDO::ERRMODE_WARNING</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Вызывает диагностику ошибок уровня <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong>.
         </span>
        </dd>
       
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.errmode-exception">PDO::ERRMODE_EXCEPTION</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Выбрасывает <span class="classname"><a href="class.pdoexception.php" class="classname">PDOException</a></span>.
         </span>
        </dd>
       
      </dl>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-oracle-nulls">PDO::ATTR_ORACLE_NULLS</a></code></strong></dt>
     <dd>
      <blockquote class="note"><p><strong class="note">Замечание</strong>: 
       <span class="simpara">
        Атрибут доступен для всех драйверов, а не только для Oracle.
       </span>
      </p></blockquote>
      <p class="para">
       Определяет, требуется ли и как преобразовывать значения <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong> и пустые строки.
       Принимает значение из следующего списка:
      </p>
      <dl>
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.null-natural">PDO::NULL_NATURAL</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Никакого преобразования не происходит.
         </span>
        </dd>
       
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.null-empty-string">PDO::NULL_EMPTY_STRING</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Пустые строки преобразуются в <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong>.
         </span>
        </dd>
       
       
        <dt><strong><code><a href="pdo.constants.php#pdo.constants.null-to-string">PDO::NULL_TO_STRING</a></code></strong></dt>
        <dd>
         <span class="simpara">
          Значение <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong> преобразуется в пустую строку.
         </span>
        </dd>
       
      </dl>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-stringify-fetches">PDO::ATTR_STRINGIFY_FETCHES</a></code></strong></dt>
     <dd>
      <p class="para">
       Управляет преобразованием извлечённых значений (кроме <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong>) в строки.
       Атрибут принимает логическое значение (<span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>):
       <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> для включения и <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> для отключения. Значение по умолчанию равняется <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong>.
       Значения <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong> остаются неизменными, если только для атрибута <strong><code><a href="pdo.constants.php#pdo.constants.attr-oracle-nulls">PDO::ATTR_ORACLE_NULLS</a></code></strong>
       не установили значение <strong><code><a href="pdo.constants.php#pdo.constants.null-to-string">PDO::NULL_TO_STRING</a></code></strong>.
      </p>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-statement-class">PDO::ATTR_STATEMENT_CLASS</a></code></strong></dt>
     <dd>
      <p class="para">
       Установка пользовательского класса оператора, производного от PDOStatement.
       Требуется <code class="literal">array(string classname, array(mixed constructor_args))</code>.
      </p>
      <div class="caution"><strong class="caution">Предостережение</strong>
       <p class="simpara">
        Не может использоваться с постоянными экземплярами PDO.
       </p>
      </div>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-timeout">PDO::ATTR_TIMEOUT</a></code></strong></dt>
     <dd>
      <p class="para">
       Указывает продолжительность времени ожидания в секундах.
       Принимает значение в виде целого числа (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>).
      </p>
      <blockquote class="note"><p><strong class="note">Замечание</strong>: 
       <p class="para">
        Не каждый драйвер поддерживает этот параметр и его значение иногда отличается от драйвера к драйверу.
        Например, SQLite будет ждать до этого значения времени, прежде чем отказаться от получения блокировки на запись,
        но другие драйверы могут интерпретировать это как интервал ожидания соединения или чтения.
       </p>
      </p></blockquote>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-autocommit">PDO::ATTR_AUTOCOMMIT</a></code></strong></dt>
     <dd>
      <blockquote class="note"><p><strong class="note">Замечание</strong>: 
       <span class="simpara">
        Доступно только для драйверов OCI, Firebird и MySQL.
       </span>
      </p></blockquote>
      <p class="para">
       Требуется ли автоматически фиксировать каждый отдельный оператор.
       Атрибут принимает логическое значение (<span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>):
       <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> для включения и <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> для отключения. Значение по умолчанию равняется <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong>.
      </p>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-emulate-prepares">PDO::ATTR_EMULATE_PREPARES</a></code></strong></dt>
     <dd>
      <blockquote class="note"><p><strong class="note">Замечание</strong>: 
       <span class="simpara">
        Атрибут доступен только для драйверов СУБД OCI, Firebird и MySQL.
       </span>
      </p></blockquote>
      <p class="para">
       Включает или отключает эмуляцию подготовленных запросов.
       Отдельные драйверы не поддерживают подготовленные запросы из коробки или поддерживают ограниченно.
       Со значением <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> объект PDO будет эмулировать подготовленные запросы,
       иначе PDO будет пытаться использовать встроенные подготовленные запросы.
       PDO будет возвращаться к эмуляции подготовленного запроса,
       если драйвер не сумеет подготовить текущий запрос.
      </p>
     </dd>
    
    
     <dt><strong><code><a href="ref.pdo-mysql.php#pdo.constants.mysql-attr-use-buffered-query">PDO::MYSQL_ATTR_USE_BUFFERED_QUERY</a></code></strong></dt>
     <dd>
      <blockquote class="note"><p><strong class="note">Замечание</strong>: 
       <span class="simpara">
        Доступно только для драйвера СУБД MySQL.
       </span>
      </p></blockquote>
      <p class="para">
       Определяет, использовать ли буферизованные запросы.
       Атрибут принимает логическое значение (<span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>):
       <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> для включения и <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> для отключения. Значение по умолчанию равняется <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong>.
      </p>
     </dd>
    
    
     <dt><strong><code><a href="pdo.constants.php#pdo.constants.attr-default-fetch-mode">PDO::ATTR_DEFAULT_FETCH_MODE</a></code></strong></dt>
     <dd>
      <p class="para">
       Устанавливает режим выборки по умолчанию.
       Описание режимов даёт документация к методу <span class="methodname"><a href="pdostatement.fetch.php" class="methodname">PDOStatement::fetch()</a></span>.
      </p>
     </dd>
    
   </dl>
  </p>
 </div>


 <div class="refsect1 parameters" id="refsect1-pdo.setattribute-parameters">
  <h3 class="title">Список параметров</h3>
  <p class="para">
   <dl>
    
     <dt><code class="parameter">attribute</code></dt>
     <dd>
      <p class="para">
       Атрибут для изменения.
      </p>
     </dd>
    
    
     <dt><code class="parameter">value</code></dt>
     <dd>
      <p class="para">
       Значение для установки параметра <code class="parameter">attribute</code>,
       иногда требует конкретный тип в зависимости от атрибута.
      </p>
     </dd>
    
   </dl>
  </p>
 </div>


 <div class="refsect1 returnvalues" id="refsect1-pdo.setattribute-returnvalues">
  <h3 class="title">Возвращаемые значения</h3>
  <p class="para">
   Функция возвращает <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong>, если выполнилась успешно, или <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong>, если возникла ошибка.
  </p>
 </div>


 <div class="refsect1 seealso" id="refsect1-pdo.setattribute-seealso">
  <h3 class="title">Смотрите также</h3>
  <p class="para">
   <ul class="simplelist">
    <li><span class="function"><a href="pdo.getattribute.php" class="function" rel="rdfs-seeAlso">PDO::getAttribute()</a> - Получает атрибут соединения с базой данных</span></li>
    <li><span class="function"><a href="pdostatement.getattribute.php" class="function" rel="rdfs-seeAlso">PDOStatement::getAttribute()</a> - Получение значения атрибута запроса PDOStatement</span></li>
    <li><span class="function"><a href="pdostatement.setattribute.php" class="function" rel="rdfs-seeAlso">PDOStatement::setAttribute()</a> - Устанавливает атрибут объекту PDOStatement</span></li>
   </ul>
  </p>
 </div>


</div><?php manual_footer($setup); ?>