带大括号的 Postgresql FromSqlInterpolated 查询

Postgresql FromSqlInterpolated query with braces

尝试使用 FromSqlInterpolated 查询 postgres 数据库,特别是 table 的 jsonb 列,因此,我需要在查询中使用大括号。

这是 postgresql 中的查询:

SELECT ass.* from "assignment" ass WHERE ass."data"-> 'SubAssignmentCodes' @> '[{"Code": "remoteName"}]' or code = '{remoteName}'

现在尝试将该查询放入 FromSqlInterpolated。

问题是 c# 认为这部分查询中的大括号 ('[{"Code": "remoteName"}]') 是插值大括号而不是查询的大括号。

我显然可以转义它们,但在这样做时,它会从提交到数据库的最终查询中一起删除大括号。

我什至尝试将查询的那部分分开:

.FromSqlInterpolated($"SELECT ass.* from \"assignment\" ass WHERE ass.\"data\" -> 'SubAssignmentCodes' @> {lastBit}::jsonb  or code = '{assignmentCode}'") 

var lastBit = "'[{{\"Code\": \"{assignmentCode}\"}}]'";

这个查询几乎可以工作,但给出了这个错误:

Npgsql.PostgresException: '22P02: invalid input syntax for type json'

这是我最初的尝试:

.FromSqlInterpolated($"SELECT ass.* from \"assignment\" ass WHERE ass.\"data\"-> 'SubAssignmentCodes' @> '[{{\"Code\": {assignmentCode}}}]' or code = {assignmentCode}")

我将 lastBit 更改为:

var lastBit = System.Text.Json.JsonSerializer.Serialize(new[] { new { Code = "assignmentCode" } });

现在可以使用了。 原来它确实无效 JSON 并正确序列化它而不是自己将 JSON 写入字符串是解决方案.