ホームページ > バックエンド開発 > PHPの問題 > PHPのPDOとは何ですか?

PHPのPDOとは何ですか?

Guanhui
リリース: 2023-03-01 17:06:01
オリジナル
3801 人が閲覧しました

PHPのPDOとは何ですか?

PHP の PDO 拡張機能とは何ですか?

PDO は PHP のデータ オブジェクト拡張機能です。この拡張機能は、PHP がデータベースにアクセスするための軽量で一貫したインターフェイスを定義し、ユーザーが使用するデータベースに関係なくデータベースにアクセスできるようにするデータ アクセス抽象化レイヤーを提供します。 . と同様のメソッドを使用して、データのクエリと取得を行うことができます。

#推奨 PDO ビデオ チュートリアル: 「

PDO データベース抽象化レイヤー

PDO インストール#PDO 拡張機能がインストールされているかどうかは、PHP の phpinfo() 関数を通じて確認できます。

Unix システムへの PDO のインストール

Unix または Linux では、次の拡張機能を追加する必要があります:

extension=pdo.so
ログイン後にコピー

Windows ユーザー

PDO とすべての主要なドライバーは次のとおりです。これらを有効にするには、php.ini ファイルを編集して次の拡張子を追加します:

extension=php_pdo.dll さらに、次の拡張子に対応するさまざまなデータベースがあります:

;extension=php_pdo_firebird.dll
;extension=php_pdo_informix.dll
;extension=php_pdo_mssql.dll
;extension=php_pdo_mysql.dll
;extension=php_pdo_oci.dll
;extension=php_pdo_oci8.dll
;extension=php_pdo_odbc.dll
;extension=php_pdo_pgsql.dll
;extension=php_pdo_sqlite.dll
ログイン後にコピー

これらの構成を設定した後、PHP または Web サーバーを再起動する必要があります。

次に、具体的な例を見てみましょう。以下は、PDO を使用して MySql データベースに接続する例です:

<?php
$dbms=&#39;mysql&#39;;     //数据库类型
$host=&#39;localhost&#39;; //数据库主机名
$dbName=&#39;test&#39;;    //使用的数据库
$user=&#39;root&#39;;      //数据库连接用户名
$pass=&#39;&#39;;          //对应的密码
$dsn="$dbms:host=$host;dbname=$dbName";
try {
    $dbh = new PDO($dsn, $user, $pass); //初始化一个PDO对象
    echo "连接成功<br/>";
    /*你还可以进行一次搜索操作
    foreach ($dbh->query(&#39;SELECT * from FOO&#39;) as $row) {
        print_r($row); //你可以用 echo($GLOBAL); 来看到这些值
    }
    */
    $dbh = null;
} catch (PDOException $e) {
    die ("Error!: " . $e->getMessage() . "<br/>");
}
//默认这个不是长连接,如果需要数据库长连接,需要最后加一个参数:array(PDO::ATTR_PERSISTENT => true) 变成这样:
$db = new PDO($dsn, $user, $pass, array(PDO::ATTR_PERSISTENT => true));
?>
ログイン後にコピー

推奨チュートリアル: "
PHP

以上がPHPのPDOとは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート