首頁 > 資料庫 > mysql教程 > 使用 PHP SQL 準備語句時如何避免程式碼重複?

使用 PHP SQL 準備語句時如何避免程式碼重複?

DDD
發布: 2024-12-25 18:30:14
原創
909 人瀏覽過

How Can I Avoid Code Repetition When Using PHP SQL Prepared Statements?

避免 PHP SQL 準備語句中的程式碼重複

在大多數 PHP SQL 準備語句範例中,欄位名稱會重複多次。如果需要進行更改,這種重複可能會很冗長且容易出錯。以下是一些最小化冗餘的解決方案:

原始PHP

省略查詢中的fields 子句並使用位置佔位符,您可以減少冗長。確保所有表列都有值,即使它們為空或預設值。

$data = [$taskName, $startDate, $completedDate];
$sql = 'INSERT INTO tasks VALUES(null, ?, ?, ?)';
$db->prepare($sql)->execute($data);
登入後複製

輔助函數

為插入建立輔助函數可以進一步簡化程式碼。此函數應警惕透過欄位名稱進行的 SQL 注入。

function prepared_insert($conn, $table, $data) {
    $keys = array_keys($data);
    $keys = array_map('escape_mysql_identifier', $keys);
    $fields = implode(",", $keys);
    $table = escape_mysql_identifier($table);
    $placeholders = str_repeat('?', count($keys) - 1) . '?';
    $sql = "INSERT INTO $table ($fields) VALUES ($placeholders)";
    $conn->prepare($sql)->execute(array_values($data));
}
登入後複製

Baby 物件關係映射器 (ORM)

此方法使用物件導向程式設計來自動化插入的建立。基底類別包含通用方法,特定表定義為子類別。

public function create($data): int
{
    $fields = $this->makeFieldList($data);
    $placeholders = str_repeat('?', count($data) - 1) . '?';

    $sql = "INSERT INTO `$this->table` ($fields) VALUES ($placeholders)";
    $this->sql($sql, array_values($data));

    return $this->db->lastInsertId();
}
登入後複製
class UserGateway extends BasicTableGateway {
    protected $table = 'gw_users';
    protected $fields = ['email', 'password', 'name', 'birthday'];
}

$data = [
    'email' => '[email protected]',
    'password' => 123,
    'name' => 'Fooster',
];

$userGateway = new UserGateway($pdo);

$id = $userGateway->create($data);
echo "Create: $id", PHP_EOL;
登入後複製

這些解決方案透過使用較少的程式碼並避免重複的欄位名稱來消除冗餘。

以上是使用 PHP SQL 準備語句時如何避免程式碼重複?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板