猿问

Golang SQL 包 jsonb 运算符

例如,在 postgresql jsonb 的 sql 包中,我如何使用@>带有字符串查询的运算符

  • WHERE data @> '{"stringdata": $1}' 或者

  • WHERE data @> '{"stringdata": "$1"}' 不起作用

另一种选择是data->>'string_data' = $1我不喜欢多个语句

错误是:

 "Message": "invalid input syntax for type json",

    "Detail": "Token \"$\" is invalid.”,

    "Where": "JSON data, line 1: $...",

    "Routine": "report_invalid_token"


慕盖茨4494581
浏览 213回答 1
1回答

慕村225694

AFAIK,您不能在字符串内部进行插值,但您可以使用or构建一个 JSON 对象:json_build_objectjson_objectSELECT data FROM testWHERE data @> json_build_object('stringdata', $1::text, 'foo', $2::int)::jsonb;这基本上相当于SELECT data FROM testWHERE data @> '{"stringdata":"$1","foo":$2}';
随时随地看视频慕课网APP

相关分类

Go
我要回答