为了账号安全,请及时绑定邮箱和手机立即绑定

Golang SQL 包 jsonb 运算符

Golang SQL 包 jsonb 运算符

Go
慕盖茨4494581 2021-11-08 16:14:15
例如,在 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"
查看完整描述

1 回答

?
慕村225694

TA贡献1880条经验 获得超4个赞

AFAIK,您不能在字符串内部进行插值,但您可以使用or构建一个 JSON 对象:json_build_objectjson_object


SELECT data FROM test

WHERE data @> json_build_object('stringdata', $1::text, 'foo', $2::int)::jsonb;

这基本上相当于


SELECT data FROM test

WHERE data @> '{"stringdata":"$1","foo":$2}';


查看完整回答
反对 回复 2021-11-08
  • 1 回答
  • 0 关注
  • 212 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信