考虑以下json描述存储在postgres数据库的json列中的文件:
{
"e8af43c1-16d3-4f9b-900b-0abec048aa62": { "name": "foo", "size": 1024 },
"1d83d835-d7d2-4433-adb7-05dcd9b3397e": { "name": "bar", "size": 512 },
...
"60394d82-7134-42ca-8fb0-1211360c3a72": { "name": "baz", "size": 1 }
}
在postgres中,可以通过以下键从json列中选择这些文件中的任何一个:
SELECT json_column->'60394d82-7134-42ca-8fb0-1211360c3a72' FROM files
是否可以使用pdo从php传递json选择器作为参数?我想象的是:
public function get_file_details($file_id) {
$sql = "SELECT json_column->':file_id' FROM files";
$stmt = $this->db->prepare($sql);
$stmt->bindParam(':file_id', $file_id, PDO::PARAM_STR);
$stmt->execute();
return $stmt->fetchColumn();
}
但这并不奏效。
此SQL肯定适用于您的情况:
select
(
select value from jsonb_each(files.json_column) as t(key, value)
where key = :file_id
) from files;
所以有一行发生了变化:
$sql = <<<SQLSTRING
select
(
select value from jsonb_each(files.json_column) as t(key, value)
where key = :file_id
) from files;
SQLSTRING;
其余部分保持不变。