Web サイト開発では、データベース操作が非常に一般的です。 PHP 言語の場合、データベースへのクエリも非常に重要な機能です。 PHP では、MySQLi と PDO 拡張機能を使用してデータベースを操作します。
MySQLi と PDO を使用してデータベースにクエリを実行する場合、通常は長いコードを記述する必要があり、不必要なコード量と開発時間が増加します。この状況に対応して、データベースからクエリされる関数をカプセル化してコードの最適化を実現し、開発効率を向上させることができます。
1. MySQLi クエリのカプセル化関数
MySQLi クエリを使用する場合、次のクエリ関数をカプセル化できます:
function connectDb() { $servername = "yourservername"; $username = "yourusername"; $password = "yourpassword"; $dbname = "yourdbname"; // 创建连接 $conn = new mysqli($servername, $username, $password, $dbname); // 检测连接 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } return $conn; }
function selectDb($query) { $conn = connectDb(); $result = $conn->query($query); if ($result === false) { die("查询失败: " . $conn->error); } $data = array(); while ($row = $result->fetch_assoc()) { $data[] = $row; } $conn->close(); return $data; }
function updateDb($query) { $conn = connectDb(); if ($conn->query($query) === true) { $status = true; } else { $status = false; } $conn->close(); return $status; }
2 . PDO クエリのカプセル化関数
PDO クエリを使用する場合、次のクエリ関数をカプセル化できます:
function connectDb() { $host = "yourhost"; $username = "yourusername"; $password = "yourpassword"; $dbname = "yourdbname"; try { $conn = new PDO("mysql:host=$host;dbname=$dbname;charset=utf8", $username, $password); // 设置 PDO 错误模式为异常 $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); } catch(PDOException $e) { echo "连接失败: " . $e->getMessage(); } return $conn; }
function selectDb($query) { $conn = connectDb(); $stmt = $conn->prepare($query); $stmt->execute(); $data = array(); while ($row = $stmt->fetch()) { $data[] = $row; } $conn = null; return $data; }
function updateDb($query) { $conn = connectDb(); $status = true; try { $conn->beginTransaction(); $stmt = $conn->prepare($query); $stmt->execute(); $conn->commit(); } catch(PDOException $e) { $conn->rollBack(); $status = false; } $conn = null; return $status; }
上記 2 つのクエリ カプセル化関数を使用することで、クエリを大幅に削減できます。データベースに必要なコード行数により、コード効率と開発効率が向上します。
概要
開発において、関数のカプセル化は、コードの品質と開発効率を向上させるために不可欠な部分です。データベース クエリ操作を実行する場合、データベース クエリのカプセル化機能を使用してクエリ コードを最適化し、開発効率を向上させることができます。上記のパッケージ機能は参照のみを目的としており、読者は特定のプロジェクトのニーズに応じて変更や改善を行うことができます。
以上がPHP はデータベースクエリ関数をカプセル化しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。