是否可以使用pdo在php中传递postgresjson选择器作为参数



考虑以下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;

其余部分保持不变。

最新更新