<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/mysql.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'mysqlinfo.library.choosing.php',
    1 => 'Выбор библиотеки',
    2 => 'Выбор библиотеки',
  ),
  'up' => 
  array (
    0 => 'mysql.php',
    1 => 'Обзор PHP-драйверов MySQL',
  ),
  'prev' => 
  array (
    0 => 'mysqlinfo.api.choosing.php',
    1 => 'Выбор API-интерфейса',
  ),
  'next' => 
  array (
    0 => 'mysqlinfo.concepts.php',
    1 => 'Основные понятия',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/mysqlinfo/set.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="mysqlinfo.library.choosing" class="chapter">
   <h1 class="title">Выбор библиотеки</h1>

   <p class="simpara">
    Модули mysqli и PDO_MySQL — легковесные обёртки поверх клиентской библиотеки языка C.
    Модули работают либо с библиотекой драйвера <a href="book.mysqlnd.php" class="link">mysqlnd</a>,
    либо с клиентской библиотекой языка C <code class="literal">libmysqlclient</code>.
    Библиотеку выбирают на этапе компиляции.
   </p>
   <p class="simpara">
    Библиотека mysqlnd — часть дистрибутива PHP.
    Библиотека предлагает функции наподобие ленивых соединений и кеширования запросов,
    включая средства, которые недоступны в библиотеке libmysqlclient,
    поэтому настоятельно рекомендуется выбирать встроенную в PHP библиотеку mysqlnd.
    <a href="book.mysqlnd.php" class="link">Документация по mysqlnd</a> даёт дополнительную информацию
    и список средств и функциональности, которую предлагает драйвер.
   </p>
   <div class="example" id="example-1">
    <p><strong>Пример #1 Команды конфигурирования модуля mysqlnd или библиотеки libmysqlclient</strong></p>
    <div class="example-contents">
<div class="shellcode"><pre class="shellcode">// Рекомендуется, компилируется с драйвером mysqlnd
$ ./configure --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd

// Рекомендуется, компилируется с драйвером mysqlnd
$ ./configure --with-mysqli --with-pdo-mysql

// Не рекомендуется, компилируется с библиотекой libmysqlclient языка C
$ ./configure --with-mysqli=/path/to/mysql_config --with-pdo-mysql=/path/to/mysql_config</pre>
</div>
    </div>

   </div>
   <p class="simpara">
    <strong>Сравнение библиотек</strong>
   </p>
   <p class="simpara">
    PHP-программистам рекомендуют работать с драйвером <a href="book.mysqlnd.php" class="link">mysqlnd</a>,
    а не с клиентской библиотекой MySQL Client Server, которая распространяется как пакет libmysqlclient.
    Обе библиотеки поддерживаются и непрерывно совершенствуются.
   </p>
   <table id="mysqlinfo.library.choosing.changelog" class="doctable informaltable">
    
     <thead>
      <tr>
       <th class="empty">&nbsp;</th>
       <th>Родной PHP-драйвер MySQL Native Driver (<a href="book.mysqlnd.php" class="link">mysqlnd</a>)</th>
       <th>Клиентская библиотека MySQL Client Server (<code class="literal">libmysqlclient</code>)</th>
      </tr>

     </thead>

     <tbody class="tbody">
      <tr>
       <td>Часть дистрибутива PHP</td>
       <td>Да</td>
       <td>Нет</td>
      </tr>

      <tr>
       <td>Версия PHP, в которой появилась библиотека</td>
       <td>5.3.0</td>
       <td>Нет данных</td>
      </tr>

      <tr>
       <td>Лицензия</td>
       <td>PHP License 3.01</td>
       <td>Двойная лицензия</td>
      </tr>

      <tr>
       <td>Статус разработки</td>
       <td>Активный</td>
       <td>Активный</td>
      </tr>

      <tr>
       <td>Жизненный цикл</td>
       <td>Окончание не анонсировано</td>
       <td>Окончание не анонсировано</td>
      </tr>

      <tr>
       <td>Компиляция по умолчанию (для всех модулей MySQL)</td>
       <td>Да</td>
       <td>Нет</td>
      </tr>

      <tr>
       <td>Поддержка протокола сжатия</td>
       <td>Да</td>
       <td>Да</td>
      </tr>

      <tr>
       <td>Поддержка протокола SSL</td>
       <td>Да</td>
       <td>Да</td>
      </tr>

      <tr>
       <td>Поддержка именованных конвейеров</td>
       <td>Да</td>
       <td>Да</td>
      </tr>

      <tr>
       <td>Неблокирующие асинхронные запросы</td>
       <td>Да</td>
       <td>Нет</td>
      </tr>

      <tr>
       <td>Статистика производительности</td>
       <td>Да</td>
       <td>Нет</td>
      </tr>

      <tr>
       <td>
        Конфигурация LOAD LOCAL INFILE учитывает директиву <a href="ini.core.php#ini.open-basedir" class="link">open_basedir</a>
       </td>
       <td>Да</td>
       <td>нет</td>
      </tr>

      <tr>
       <td>
        Взаимодействие со внутренней системой управления памятью PHP (например, соблюдение ограничений памяти PHP)
       </td>
       <td>Да</td>
       <td>Нет</td>
      </tr>

      <tr>
       <td>Возврат числовых столбцов как целочисленных значений double (COM_QUERY)</td>
       <td>Да</td>
       <td>нет</td>
      </tr>

      <tr>
       <td>Возврат числовых столбцов как строк (string) (COM_QUERY)</td>
       <td>Да</td>
       <td>Да</td>
      </tr>

      <tr>
       <td>Поддержка API плагинов</td>
       <td>Да</td>
       <td>Ограниченно</td>
      </tr>

      <tr>
       <td>Автоматическое переподключение</td>
       <td>нет</td>
       <td>опционально</td>
      </tr>

     </tbody>
    
   </table>

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