gpt4 book ai didi

php - 为什么创建自定义 PDO 查询处理程序是愚蠢的?

转载 作者:搜寻专家 更新时间:2023-10-31 22:04:33 25 4
gpt4 key购买 nike

<分区>

根据这个线程:https://codereview.stackexchange.com/questions/29362/very-simple-php-pdo-class人们通常说创建自定义 PDO 查询处理程序很愚蠢,我发现这很难理解。

例如,在我的项目中,我更喜欢有一个类/函数来做我一直做的事情,对我来说更快。

例如,当您需要在表中执行简单的更新时,我创建了这个函数,我一直在使用它:

function UpdateData($table, $data, $where, $params=array()) {
$sql = 'UPDATE `' . tbl_prefix.$table . '` SET ';
foreach($data as $name => $value) {
$params[':' . $name] = $value;
$runs++;
$sql .= "`$name` = :" . $name;

if(end($data) !== $value) // if not last run
$sql .= ',';
}

if(!is_array($where)) {
$sql .= ' ' . $where; // insert where clause
} else {
// Array format can be used
$sql .= ' WHERE';

foreach($where as $argument => $value) {
$params[':where_'.$argument] = $value;

$num++;
$sql .= " `" . $argument . "` = :where_" . $argument . " ";

if(end($where) !== $value)
$sql .= ' AND';
}
}

$query = doQuery($sql, $params); // do the update

if($query)
return true;
}

还有 doQuery(我在查询数据库时也会用到):

function doQuery($query, $params=array()) {
global $db;
try {
$result = $this->$db->prepare($query);
$result->execute($params);
$result->setFetchMode(PDO::FETCH_ASSOC);

return $result;
} catch(PDOException $ex) {
$real_query = $query;
foreach($params as $name => $value) {
$real_query = str_replace($name, '\''.$value.'\'', $real_query);
}

SystemLog($ex->GetMessage(), array('real_query' => $real_query, 'query' => $query), 1); // log error
}

return false;
}

这有什么问题吗?我发现它非常有用。

一些代码已从脚本中取出以简化代码

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com