我有一个包含 JSON 类型对象(列类型nvarchar
)的单列表,并且需要过滤行。
JSON对象是一个包含多个字段的对象数组,有没有一种方法可以在数组的每个值上应用 between 子句,如果匹配则返回该行。
ROW_1 = [{"key": 12}, {"key": 13}, {"key": 19}]
对于上述字符串,如果 between 子句的范围在 15 到 22 之间,则应选择该行。
我在上述要求中看到了两个挑战,1 是使用 wild_cards 来选择所有键,而另一个是在每个值上应用 between 子句。
类似的用例是选择一行,如果它与我执行以下操作的值匹配
select *
from table
where CAST(JSON_QUERY(column, '$'), nvarchar(max)) LIKE '%"key": 12%'
让我知道这是否可以使用 T-SQL 查询来完成。
PS。其他替代方法包括使用 python 加载所有数据并在那里过滤。(但我担心的是,我每次都需要加载完整的数据,这可能会由于未来行数的增加而减慢过滤速度)。