Webエンジニア向けプログラミング解説動画をYouTubeで配信中!
▶ チャンネル登録はこちら

【PHP8.x】PDO::ATTR_PERSISTENT定数の使い方

ATTR_PERSISTENT定数の使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

ATTR_PERSISTENT定数は、PHPのPDO拡張機能において、データベースへの永続的な接続を制御するために使用される定数です。

PHPアプリケーションがデータベースにアクセスする際、通常はリクエストごとにデータベース接続を確立し、スクリプトの実行が終了するとその接続は切断されます。しかし、高頻度でデータベースアクセスが必要なウェブアプリケーションなどでは、この接続の確立と切断の繰り返しがパフォーマンス上のオーバーヘッドとなることがあります。

この定数にtrueを設定してPDOオブジェクトを生成することで、PHPプロセスが終了した後もデータベースとの接続を維持する「永続接続」が有効になります。永続接続が有効になると、次に同じデータベースへの接続が必要になった際に、既存の接続が再利用されるため、接続確立にかかる時間を削減し、アプリケーション全体のパフォーマンス向上に貢献します。

設定は、new PDO($dsn, $user, $password, [PDO::ATTR_PERSISTENT => true]);のように、PDOクラスのコンストラクタオプションとして指定することが一般的です。

ただし、永続接続はサーバーのリソースを継続的に消費するため、その管理には注意が必要です。不適切な利用は、データベースサーバーのリソース枯渇を招く可能性があります。また、以前の接続で設定されたトランザクションの状態や、セッション固有の情報が次回の接続に引き継がれることもあり得るため、予期せぬ動作を避けるためにはアプリケーションの設計に十分な注意が必要です。性能向上というメリットの一方で、これらのリスクも存在するため、特性を理解した上で慎重な導入が推奨されます。

構文(syntax)

1<?php
2$dsn = 'mysql:host=localhost;dbname=testdb';
3$user = 'your_username';
4$password = 'your_password';
5
6$options = [
7    PDO::ATTR_PERSISTENT => true,
8];
9
10try {
11    $pdo = new PDO($dsn, $user, $password, $options);
12} catch (PDOException $e) {
13    // 接続エラー処理
14}

引数(parameters)

引数なし

引数はありません

戻り値(return)

戻り値なし

戻り値はありません

関連コンテンツ