首页 > 数据库 > mysql教程 > 如何减少 PHP SQL 准备语句中的代码重复?

如何减少 PHP SQL 准备语句中的代码重复?

Barbara Streisand
发布: 2024-12-26 07:06:13
原创
942 人浏览过

How Can I Reduce Code Repetition in PHP SQL Prepared Statements?

克服 PHP SQL 准备语句中的代码重复

在典型的 PHP SQL 准备语句中,字段名称被多次提及,导致冗余。要解决此问题,请考虑以下解决方案:

原始 PHP 技术

  • 在查询中省略 fields 子句,并在 value 子句中为缺失字段添加默认值。
  • 使用位置占位符,为所有列提供值,包括表中定义的空值或默认值定义。
$data = [$taskName, $startDate, $completedDate];
$sql = 'INSERT INTO tasks VALUES(null, ?, ?, ?)';
$db->prepare($sql)->execute($data);
登录后复制

辅助函数方法

为接受表名和数据数组的插入创建辅助函数,处理 SQL 注入问题:

function escape_mysql_identifier($field){
    return "`".str_replace("`", "``", $field)."`";
}

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));
}
登录后复制
prepared_insert($db, 'tasks',[
    'task_name' => $taskName,
    'start_date' => $startDate,
    'completed_date' => $completedDate,
]);
登录后复制

面向对象编程

使用对象实现一个小型 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
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板