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

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

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

作成日: 更新日:

基本的な使い方

PDO::FETCH_CLASS定数は、PHPのPDO拡張機能において、データベースからデータを取得する際のフェッチモードの一つを表す定数です。これは、PDOStatement::fetch()PDOStatement::fetchAll()などのメソッドで使用され、データベースのクエリ結果セットの各行を、指定されたPHPクラスの新しいインスタンスとして取得することを可能にします。

具体的には、データベースのカラム名と一致する名前を持つクラスのプロパティに、対応するカラムの値が自動的に設定されます。これにより、データベースから取得した生データを直接連想配列や数値添字配列として扱うのではなく、明確な構造を持つオブジェクトとして操作できるようになります。

オブジェクト指向プログラミングにおいて、データベースのレコードをアプリケーション内のデータモデルオブジェクトとして表現する際に非常に有用です。例えば、Userクラスがある場合、PDO::FETCH_CLASSを使うことで、データベースのusersテーブルから取得した各行をUserオブジェクトのインスタンスとして扱うことができます。これは、コードの可読性を高め、データの整合性を保ち、PHPの型ヒントなどの機能と連携しやすくなるため、より堅牢で保守しやすいアプリケーション開発に貢献します。また、クラスのコンストラクタに引数を渡すことも可能で、オブジェクトの初期化をより柔軟に行うことができます。

構文(syntax)

1<?php
2
3class MyDataClass
4{
5    public $id;
6    public $name;
7}
8
9try {
10    $pdo = new PDO('sqlite::memory:');
11    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
12
13    $pdo->exec("CREATE TABLE my_table (id INTEGER PRIMARY KEY, name TEXT)");
14    $pdo->exec("INSERT INTO my_table (name) VALUES ('Sample Item')");
15
16    $stmt = $pdo->prepare("SELECT id, name FROM my_table WHERE id = :id");
17    $stmt->bindValue(':id', 1);
18    $stmt->execute();
19
20    $object = $stmt->fetch(PDO::FETCH_CLASS, 'MyDataClass');
21
22    if ($object) {
23        echo "ID: " . $object->id . "\n";
24        echo "Name: " . $object->name . "\n";
25    }
26
27} catch (PDOException $e) {
28    // エラー処理
29}
30
31?>

引数(parameters)

引数なし

引数はありません

戻り値(return)

戻り値なし

戻り値はありません

サンプルコード

PHP PDO::FETCH_CLASSでユーザーをオブジェクト取得

1<?php
2
3/**
4 * データベースからユーザー情報を取得し、Userクラスのオブジェクトとして返すサンプルコードです。
5 *
6 * システムエンジニアを目指す初心者向けに、PHPのPDO::FETCH_CLASS定数の基本的な使い方を示します。
7 * この定数を使用すると、データベースの各行を特定のPHPクラスの新しいインスタンスにマッピングし、
8 * オブジェクト指向的な方法でデータを取り扱うことができます。
9 */
10function fetchUsersAsObjects(): void
11{
12    // 1. データベース接続の確立
13    // SQLiteのインメモリデータベースを使用することで、ファイルを作成せずにこのスクリプトを単体で実行できます。
14    // 実際のアプリケーションでは、データベースサーバーのアドレスや認証情報を使用します。
15    try {
16        $pdo = new PDO('sqlite::memory:');
17        // PDOがエラーを例外としてスローするように設定し、エラーハンドリングを容易にします。
18        $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
19        echo "データベースに接続しました。\n";
20    } catch (PDOException $e) {
21        // データベース接続に失敗した場合のエラー処理
22        die("データベース接続エラー: " . $e->getMessage() . "\n");
23    }
24
25    // 2. テスト用テーブルの作成とデータの挿入
26    // 実際のアプリケーションでは、通常はテーブルが事前に作成されていることを前提とします。
27    try {
28        // usersテーブルを作成します。既に存在する場合は何もしません。
29        $pdo->exec("CREATE TABLE IF NOT EXISTS users (
30            id INTEGER PRIMARY KEY AUTOINCREMENT,
31            name TEXT NOT NULL,
32            email TEXT NOT NULL UNIQUE
33        )");
34        echo "テーブル 'users' を作成しました(存在しない場合)。\n";
35
36        // テストデータを挿入します。
37        // 同じメールアドレスを複数回挿入しようとするとUNIQUE制約違反になるため、エラーを無視します。
38        $stmt = $pdo->prepare("INSERT OR IGNORE INTO users (name, email) VALUES (?, ?)");
39        $stmt->execute(['Taro Yamada', 'taro@example.com']);
40        $stmt->execute(['Hanako Suzuki', 'hanako@example.com']);
41        echo "テストデータを挿入しました。\n";
42
43    } catch (PDOException $e) {
44        // テーブル作成やデータ挿入に失敗した場合のエラー処理
45        die("データベース初期化エラー: " . $e->getMessage() . "\n");
46    }
47
48    // 3. データベースから取得したデータをマッピングするためのクラスを定義
49    // このUserクラスのプロパティ名(id, name, email)は、
50    // データベーステーブルの列名と一致させることでPDOが自動的にデータをマッピングします。
51    // PHP 8ではプロパティに型を宣言することが推奨されます。
52    class User
53    {
54        public int $id;
55        public string $name;
56        public string $email;
57    }
58
59    // 4. PDO::FETCH_CLASS を使用してデータをオブジェクトとして取得
60    try {
61        // usersテーブルからすべてのユーザー情報を選択するSQLクエリを準備します。
62        $stmt = $pdo->prepare("SELECT id, name, email FROM users");
63        $stmt->execute();
64
65        echo "\n--- ユーザー情報をオブジェクトとして取得します ---\n";
66
67        // fetchAll() メソッドに PDO::FETCH_CLASS 定数とクラス名(User::class)を指定することで、
68        // 取得した各行が User クラスの新しいインスタンスとして配列で返されます。
69        /** @var User[] $users */ // このコメントはIDEが型ヒントを理解するために役立ちます
70        $users = $stmt->fetchAll(PDO::FETCH_CLASS, User::class);
71
72        if (empty($users)) {
73            echo "取得されたユーザーがいません。\n";
74        } else {
75            // 取得した各Userオブジェクトをループで処理し、そのプロパティにアクセスして表示します。
76            foreach ($users as $user) {
77                // $user は User クラスのインスタンスなので、$user->プロパティ名 でデータにアクセスできます。
78                echo "ID: " . $user->id . ", 名前: " . $user->name . ", メール: " . $user->email . "\n";
79            }
80        }
81        echo "--- 取得完了 ---\n";
82
83    } catch (PDOException $e) {
84        // データ取得中にエラーが発生した場合の処理
85        echo "データ取得エラー: " . $e->getMessage() . "\n";
86    }
87}
88
89// 定義した関数を実行して、サンプルコードの動作を確認します。
90fetchUsersAsObjects();

PHPのPDO::FETCH_CLASS定数は、データベースから取得した各行のデータを、指定したPHPクラスのインスタンス(オブジェクト)として受け取るための設定です。システムエンジニアを目指す初心者の方にとって、データベースのデータをオブジェクトとして扱うことは、より直感的で管理しやすく、エラーが少ないコードを書く上で非常に役立ちます。

このサンプルコードでは、まずデータベースに接続し、簡単なusersテーブルを作成してテストデータを挿入します。次に、データベースのidnameemailといった列名に対応するプロパティを持つUserクラスを定義します。このプロパティ名と列名が一致していることが、PDOが自動的にデータをマッピングするための重要なポイントです。

データ取得の際には、$stmt->fetchAll(PDO::FETCH_CLASS, User::class)のように、fetchAll()メソッドの第一引数にPDO::FETCH_CLASS定数、第二引数にデータを受け取るUserクラス名を指定します。これにより、データベースの各行がUserクラスの新しいオブジェクトとして配列に格納され、$user->idのようにプロパティ経由で各データにアクセスできるようになります。PDO::FETCH_CLASS定数自体には引数も戻り値もありませんが、この定数をPDOStatement::fetchAllなどのメソッドに指定することで、データベースから取得されるデータの形式をオブジェクトに変換する挙動を設定します。これにより、PHPのオブジェクト指向プログラミングの利点を生かしたデータベース操作が可能となります。

PDO::FETCH_CLASS を利用する際の最も重要な注意点は、データベースの列名とPHPのクラスのプロパティ名を正確に一致させる必要がある点です。一致しない場合、データが正しくマッピングされず、プロパティに値が設定されない可能性があります。また、データを格納するクラスはシンプルな構造とし、PHP 8ではプロパティに型宣言を行うことが推奨されます。サンプルコードの User クラスのように、プロパティは public で定義し、直接データにアクセスできるようにするのが一般的です。実際のアプリケーションでは、クラス定義は独立したファイルに記述し、オートロードで読み込むようにしてください。データベース接続情報も開発環境や本番環境に合わせて適切に設定することが重要です。

PDO::FETCH_CLASS でオブジェクト取得する

1<?php
2
3/**
4 * Represents a user entity, mapping to database columns.
5 */
6class User
7{
8    public int $id;
9    public string $name;
10    public string $email;
11
12    /**
13     * Returns a string representation of the User object.
14     */
15    public function getUserInfo(): string
16    {
17        return "ID: {$this->id}, Name: {$this->name}, Email: {$this->email}";
18    }
19}
20
21/**
22 * Demonstrates the usage of PDO::FETCH_CLASS to fetch database rows into objects.
23 */
24function demonstratePdoFetchClass(): void
25{
26    // Use an in-memory SQLite database for a self-contained example.
27    $dsn = 'sqlite::memory:';
28
29    try {
30        // Establish a PDO connection.
31        $pdo = new PDO($dsn);
32        // Set error mode to exception for easier debugging.
33        $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
34
35        // Create a simple 'users' table.
36        $pdo->exec("
37            CREATE TABLE users (
38                id INTEGER PRIMARY KEY AUTOINCREMENT,
39                name VARCHAR(255) NOT NULL,
40                email VARCHAR(255) UNIQUE NOT NULL
41            );
42        ");
43
44        // Insert some sample data.
45        $stmt = $pdo->prepare("INSERT INTO users (name, email) VALUES (:name, :email)");
46        $stmt->execute([':name' => 'Alice Smith', ':email' => 'alice@example.com']);
47        $stmt->execute([':name' => 'Bob Johnson', ':email' => 'bob@example.com']);
48
49        echo "Database initialized and sample data inserted.\n\n";
50
51        // Select data from the users table.
52        $stmt = $pdo->query("SELECT id, name, email FROM users");
53
54        // Fetch all results into an array of User objects using PDO::FETCH_CLASS.
55        // The second argument specifies the class name to instantiate for each row.
56        $users = $stmt->fetchAll(PDO::FETCH_CLASS, 'User');
57
58        echo "Fetched users as objects using PDO::FETCH_CLASS:\n";
59        foreach ($users as $user) {
60            // Each $user is now an instance of the User class.
61            echo "- " . $user->getUserInfo() . "\n";
62            // We can also access properties directly: echo "- ID: {$user->id}, Name: {$user->name}\n";
63        }
64
65    } catch (PDOException $e) {
66        // Catch and display any PDO-related errors.
67        echo "Database error: " . $e->getMessage() . "\n";
68    } catch (Exception $e) {
69        // Catch any other unexpected errors.
70        echo "An unexpected error occurred: " . $e->getMessage() . "\n";
71    }
72}
73
74// Call the function to execute the demonstration.
75demonstratePdoFetchClass();

PHPのPDO::FETCH_CLASSは、データベースから取得した結果を、あらかじめ定義したPHPクラスのインスタンスとして扱うための定数です。通常、データベースのデータを取得すると連想配列などの形式で返されますが、この定数を使用すると、特定のクラス(例: Userクラス)のオブジェクトとして直接データを受け取ることができます。

具体的には、PDOStatement::fetchAll()メソッドの第一引数にPDO::FETCH_CLASSを指定し、第二引数にデータを受け取るクラス名(例: 'User')を渡します。すると、データベースの各行が指定されたクラスの新しいインスタンスとなり、対応するカラムの値が自動的にそのクラスのプロパティに格納されます。例えば、サンプルコードでは、usersテーブルの各行がUserクラスのオブジェクトとして配列に格納され、$user->nameのようにプロパティを通してデータにアクセスできるようになります。

これにより、データベースの構造とPHPのオブジェクト指向プログラミングを連携させ、コードの可読性やメンテナンス性を向上させることができます。PDO::FETCH_CLASS定数自体は引数や戻り値を持たず、データの取得形式を指示する役割を担っています。

PDO::FETCH_CLASSは、データベースの各行を、指定したクラスのオブジェクトとして取得するための定数です。利用するクラスのプロパティ名はデータベースのカラム名と正確に一致させる必要があり、通常はpublicで宣言してください。また、PHP 8で導入された型付きプロパティを使用する場合、データベースから取得される値の型とプロパティの型が一致しないとエラーとなる可能性がありますので注意が必要です。fetchAll()の第二引数には、インスタンス化するクラス名を文字列で指定してください。データベースとの安全な連携のために、PDO::ATTR_ERRMODEPDO::ERRMODE_EXCEPTIONに設定し、PDO関連のエラーは例外として捕捉する運用を推奨します。

関連コンテンツ