<?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 => 'ja',
  ),
  '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' => 'ja',
    '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="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> に設定しない限り、
       <strong><code><a href="reserved.constants.php#constant.null">null</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">
       タイムアウト秒数を指定します。
       数値を指定します。
      </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> を指定すると、
       プリペアドステートメントを常にエミュレートします。
       そうでない場合、
       ネイティブのプリペアドステートメントを使おうとします。
       ドライバが現在のクエリを正しく準備できなかった場合は、
       常にエミュレート方式を使います。
      </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="methodname"><a href="pdo.getattribute.php" class="methodname" rel="rdfs-seeAlso">PDO::getAttribute()</a> - データベース接続の属性を取得する</span></li>
    <li><span class="methodname"><a href="pdostatement.getattribute.php" class="methodname" rel="rdfs-seeAlso">PDOStatement::getAttribute()</a> - 文の属性を取得する</span></li>
    <li><span class="methodname"><a href="pdostatement.setattribute.php" class="methodname" rel="rdfs-seeAlso">PDOStatement::setAttribute()</a> - 文の属性を設定する</span></li>
   </ul>
  </p>
 </div>


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