PDO を使用して Oracle データベースに接続する方法
概要:
PDO (PHP Data Objects) は、PHP でデータベースを操作するための拡張ライブラリであり、複数の種類のデータベースにアクセスするための統合 API を提供します。 。この記事では、PDO を使用して Oracle データベースに接続し、一般的なデータベース操作を実行する方法について説明します。
手順:
;extension=php_pdo_oci.dll
;extension=php_oci8.dll
データベース接続の作成
PHP プログラムでは、次のコードを使用して、Oracle データベースに接続する PDO オブジェクトを作成できます:
$dsn = 'oci:dbname=//hostname:port/oracle_sid'; $username = 'your_username'; $password = 'your_password'; try { $conn = new PDO($dsn, $username, $password); } catch (PDOException $e) { echo 'Connection failed: ' . $e->getMessage(); exit; }
コード内では、$ dsn は、ホスト名、ポート、Oracle SID を含む文字列です。 $username と $password は、Oracle データベースに接続するために必要なユーザー名とパスワードです。
SQL クエリの実行
Oracle データベースに正常に接続したら、PDO オブジェクトを使用して SQL クエリを実行できます。以下は、データベース内のデータをクエリし、結果をブラウザに出力する方法を示す簡単な例です。
$sql = 'SELECT * FROM employees'; $stmt = $conn->query($sql); $result = $stmt->fetchAll(PDO::FETCH_ASSOC); foreach ($result as $row) { echo $row['employee_id'] . ' ' . $row['first_name'] . ' ' . $row['last_name'] . '<br>'; }
コード内で、$sql は実行する SELECT ステートメントであり、$stmt はPDOStatement オブジェクト。クエリの結果セットを表します。 PDOStatement オブジェクトの fetchAll メソッドを呼び出すと、クエリ結果を含む連想配列を取得できます。次に、foreach ループを使用して結果を反復処理し、各行のデータをブラウザーに出力します。
準備されたステートメントの実行
通常の SQL クエリに加えて、PDO は準備されたステートメントの実行もサポートします。準備されたステートメントは、データベース操作のパフォーマンスを向上させるだけでなく、SQL インジェクション攻撃を防ぐこともできます。以下は、プリペアド ステートメントを使用してデータベースにクエリを実行するサンプル コードです。
$sql = 'SELECT * FROM employees WHERE department_id = :dept_id'; $stmt = $conn->prepare($sql); $stmt->bindParam(':dept_id', $dept_id); $dept_id = 1; $stmt->execute(); $result = $stmt->fetchAll(PDO::FETCH_ASSOC); foreach ($result as $row) { echo $row['employee_id'] . ' ' . $row['first_name'] . ' ' . $row['last_name'] . '<br>'; }
コードでは、プレースホルダー (:dept_id) を使用してクエリ条件を表し、bindParam メソッドを使用してプレースホルダーを実価。次に、execute メソッドを実行してクエリを実行し、結果を $result 変数に保存します。
概要:
上記の手順により、PDO を使用して Oracle データベースに正常に接続し、いくつかの一般的なデータベース操作を実行できます。 PHP アプリケーションを開発する場合、PDO を使用してデータベースに接続すると、パフォーマンスが向上するだけでなく、セキュリティも向上します。この記事が、PDO を使用して Oracle データベースに接続する方法を理解するのに役立つことを願っています。
以上がPDO を使用して Oracle データベースに接続する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。