如何在 PDO(或 MySQLi)查询中正确处理关联数组?

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 作为标签和问题。

Dav*_*dom 5

这是一个函数,它将接受一个输入数组并生成一些可以直接放入查询中的内容,只要您只更新一个表:

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)