基本的な使用を実現するための PDO 拡張機能を介した MySQL データベースとの対話
#関連する学習に関する推奨事項:mysql チュートリアル、php プログラミング
## この内容チュートリアルでは、PHP の組み込み Mysqli 拡張機能を介して MySQL データベースと対話する方法を紹介しました。今日は、別の PHP 組み込みデータベース拡張機能 - PDO (正式名は PHP Data Objects、つまり PHP データ) を見ていきます。オブジェクト。
PDO の導入とインストール
PDO は、PHP がデータベースにアクセスするための軽量で一貫したインターフェイスを定義するため、データ アクセス抽象化レイヤーを提供し、それ自体はデータベース インタラクション関数を実装しません。特定のデータベースの PDO ドライバーを使用して、データベース サービスにアクセスします。これらの特定のデータベース ドライバーには、MySQL、PostgreSQL、SQLite、SQL Server、Oracle などが含まれます。したがって、PDO は、より標準的でより一般的なデータベース拡張機能であり、完全にオブジェクトです。現在、PDO は、PDO 拡張機能に基づいたデータベース アクセス機能も提供する Laravel フレームワークを含む、さまざまな主流の PHP フレームワークでデータベース インタラクションを構築するための基本コンポーネントとなっています。
以前に推奨した PHP ローカル統合開発環境には、すべて PDO 拡張機能のサポートが統合されています (以下は、Laragon のプリインストールされた PHP 拡張機能です):
And It
拡張子に加えて、一致する特定のデータベース拡張子 pdo_mysql
も存在することがわかります。この特定の拡張子を使用してのみ MySQL データベースにアクセスできます。さらに、PDO は統合されたデータベース アクセス インターフェイスを提供するため、PDO インターフェイスを実装する特定のデータベース拡張機能はまったく同じ方法でデータベースにアクセスでき、アプリケーションがデータベースを切り替える必要がある場合にデータベースを再構築する必要はありません。これのみに基づいて、MySQLi 拡張機能を捨てて PDO を採用することができます。 Laradock をインストールしている場合は、
コンテナを起動して、そのプリインストールされた PHP 拡張機能を表示できます。より具体的な PDO データベース ドライバーのサポートが含まれていることがわかります:
は PostgresSQL データベース ドライバーを表し、pdo_sqlite
は SQLite データベース ドライバーを表します。 データベース接続と基本的なクエリの確立
このチュートリアルでは、デモンストレーションの例として MySQL を使用することを選択します。
PDO 拡張機能を介してデータベース接続を確立するには、PDO オブジェクトを直接インスタンス化するだけです。次のような簡単なサンプル コードを作成します (
php_learning/mysql ディレクトリに pdo.php を作成します)
ストレージ コード): <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'><?php
// 设置连接属性
$dsn = &#39;mysql:host=127.0.0.1;port=3306;dbname=test;charset=utf8mb4&#39;;
$user = &#39;root&#39;;
$pass = &#39;root&#39;;
try {
// 建立连接
$pdo = new PDO($dsn, $user, $pass);
// 执行 SQL 查询
$sql = $pdo->quote(&#39;SELECT * FROM `post` ORDER BY `id` DESC&#39;);
$res = $pdo->query($sql);
// 打印查询结果
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
foreach ($res as $row) {
print_r($row);
}
} catch (PDOException $exception) {
// 如果数据库操作出现异常,则捕获并打印
printf("Error: %s\n", $exception->getMessage());
} finally {
// 释放 PDO 连接实例
$pdo = null;
}</pre><div class="contentsignin">ログイン後にコピー</div></div>
PDO オブジェクトをインスタンス化してデータベース接続を作成する場合、少なくとも 3 つの文字列型パラメーターを渡す必要があります。最初のパラメーターには、データベース ドライバーの種類などのデータベース ホスト情報が含まれます。 (ここでは
)、IP アドレス (ローカル アドレスは 127.0.0.1
)、ポート番号 (オプション、デフォルトは 3306
)、および名前接続するデータベースの情報(test
)、文字コード情報(utf8mb4
)など。第2パラメータはユーザー名、第3パラメータはパスワードです。 次に、PDO オブジェクト インスタンス
でクエリ メソッドを呼び出して、指定された SQL ステートメントを実行してデータベースと対話します (追加、削除、変更、確認)。この関数の機能は mysqli_escape_string
と似ています。 SQL クエリを実行すると、クエリ結果セットが返され、ループ トラバーサルを通じて出力できます。
また、PDO 拡張機能によるデータベース接続やクエリ操作中にエラーが発生した場合、例外がスローされます。プログラムの堅牢性を高めるために、
try...catch を使用しています。 ... このステートメント ブロックは例外に関係なく実行されるため、ステートメントは PDOException
例外をキャプチャし、エラー メッセージを出力し、最後に finally
ステートメントを通じて PDO オブジェクト インスタンスを解放します。例外がスローされるかどうか。 Run
テスト用に組み込み HTTP サーバーを起動し、http://localhost:9000/mysql/pdo.php
にアクセスします。ブラウザで、通常の印刷結果を確認できます:
上記のコードの接続情報を変更してみましょう。たとえば、パスワード値を
注: エラー メッセージ内の IP アドレスは、 MySQLのDockerコンテナ。このエラーは、IP アドレスの問題ではなく、パスワードが間違っていることが原因で発生します。
関連記事をさらに知りたい場合は、php mysql 列に注目してください。
以上が基本的な使用を実現するための PDO 拡張機能を介した MySQL データベースとの対話の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











MySQLはオープンソースのリレーショナルデータベース管理システムであり、主にデータを迅速かつ確実に保存および取得するために使用されます。その実用的な原則には、クライアントリクエスト、クエリ解像度、クエリの実行、返品結果が含まれます。使用法の例には、テーブルの作成、データの挿入とクエリ、および参加操作などの高度な機能が含まれます。一般的なエラーには、SQL構文、データ型、およびアクセス許可、および最適化の提案には、インデックスの使用、最適化されたクエリ、およびテーブルの分割が含まれます。

データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

Apacheはデータベースに接続するには、次の手順が必要です。データベースドライバーをインストールします。 web.xmlファイルを構成して、接続プールを作成します。 JDBCデータソースを作成し、接続設定を指定します。 JDBC APIを使用して、接続の取得、ステートメントの作成、バインディングパラメーター、クエリまたは更新の実行、結果の処理など、Javaコードのデータベースにアクセスします。

MySQLは、そのパフォーマンス、信頼性、使いやすさ、コミュニティサポートに選択されています。 1.MYSQLは、複数のデータ型と高度なクエリ操作をサポートし、効率的なデータストレージおよび検索機能を提供します。 2.クライアントサーバーアーキテクチャと複数のストレージエンジンを採用して、トランザクションとクエリの最適化をサポートします。 3.使いやすく、さまざまなオペレーティングシステムとプログラミング言語をサポートしています。 4.強力なコミュニティサポートを提供し、豊富なリソースとソリューションを提供します。

DockerでMySQLを起動するプロセスは、次の手順で構成されています。MySQLイメージをプルしてコンテナを作成および起動し、ルートユーザーパスワードを設定し、ポート検証接続をマップしてデータベースを作成し、ユーザーはすべての権限をデータベースに付与します。

WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。

Laravelは、Webアプリケーションを簡単に構築するためのPHPフレームワークです。次のような強力な機能を提供します。インストール:Laravel CLIを作曲家にグローバルにインストールし、プロジェクトディレクトリにアプリケーションを作成します。ルーティング:ルート/web.phpのURLとハンドラーの関係を定義します。ビュー:リソース/ビューでビューを作成して、アプリケーションのインターフェイスをレンダリングします。データベース統合:MySQLなどのデータベースとのすぐ外側の統合を提供し、移行を使用してテーブルを作成および変更します。モデルとコントローラー:モデルはデータベースエンティティを表し、コントローラーはHTTP要求を処理します。

MySQLをエレガントにインストールするための鍵は、公式のMySQLリポジトリを追加することです。特定の手順は次のとおりです。MYSQLの公式GPGキーをダウンロードして、フィッシング攻撃を防ぎます。 mysqlリポジトリファイルを追加:rpm -uvh https://dev.mysql.com/get/mysql80-community-rease-el7-3.noarch.rpm update yumリポジトリキャッシュ:yumアップデートインストールmysql:yumインストールmysql-server startup mysql sportin
