Bob*_*Bob 3 php mysqli pdo prepared-statement
我正在使用 MySQLi 进行项目(但可以轻松切换到 PDO,请阅读底部的编辑)。我想要的是能够将关联数组处理为 mysql 查询,而无需手动输入每个键/值对。我知道这可能很简单,但当涉及到 MySQLi/PDO 时,我仍然处于学习过程中。为了清楚地说明我的意思,这里有一个例子:
假设我有这个关联数组:
$data = array(
'name' => 'Objective',
'short_name' => 'OB',
'generation' => 1
);
Run Code Online (Sandbox Code Playgroud)
我想要的是创建一个像这样的查询:
UPDATE signals SET ? = ? WHERE sid = '1'
Run Code Online (Sandbox Code Playgroud)
它变成这样的查询(或者代替 UPDATE、INSERT、SELECT 等):
UPDATE signals SET
name = 'Objective',
short_name = 'OB',
generation = 1
WHERE sid = '1'
Run Code Online (Sandbox Code Playgroud)
所以基本上我的问题是:这对于 MySQLi 或 PDO 本身是否可能?如果可能的话我该怎么做?我读过关于执行前准备语句的内容,但它还没有吸引我。希望有人可以帮助我。
编辑:我还处于该项目的早期阶段,所以我也可以使用 PDO,但同样的问题仍然存在。我确实研究了 PDO 和 mysqli,但我也不知道如何使用 PDO 来做到这一点。因此,为了解决这个问题,我将添加 PDO 作为标签和问题。
这是一个函数,它将接受一个输入数组并生成一些可以直接放入查询中的内容,只要您只更新一个表:
function array_to_pdo_params($array) {
$temp = array();
foreach (array_keys($array) as $name) {
$temp[] = "`$name` = ?";
}
return implode(', ', $temp);
}
Run Code Online (Sandbox Code Playgroud)
现在您可以像这样执行 PDO 查询:
// The data
$data = array(
'name' => 'Objective',
'short_name' => 'OB',
'generation' => 1
);
// The parameter for the WHERE clause
$sid = 1;
// Build the query string
$query = "
UPDATE `signals`
SET ".array_to_pdo_params($data)."
WHERE `sid` = ?
";
// Convert the data array to indexed and append the WHERE parameter(s) to it
$queryData = array_values($data);
$queryData[] = $sid;
$stmt = $db->prepare($query); // Obviously add the appropriate error handling
$stmt->execute($queryData);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4490 次 |
| 最近记录: |