微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

以不区分大小写的方式使用json_populate_recordset

是否可以使用json_populate_recordset,以便使用Postgresql(9.6)以不区分大小写的方式比较表列名/ / json键?

例如,以下代码段将返回零行.

CREATE TABLE foo (bar TEXT);
SELECT * from json_populate_recordset(null::foo,'[{"bAr":1}]')

当然我可以将json键转换为小写,或者表名可能区分大小写.

解决方法

我不相信不区分大小写是可能的.如果您事先知道将用于记录的情况(例如,它们总是骆驼),您可以通过引用列名来指定特定情况.

显示不区分大小写的基线示例:

# create type x as (abc integer);
CREATE TYPE
# select * from json_populate_recordset(null::x,'[{"abc" : 1},{"Abc" : 2},{"aBc" : 3},{"abC" : 4}]');
 abc
-----
   1



(4 rows)

现在让我们通过引用列名来选择我们想要使用的特定案例.

# drop type x;
DROP TYPE
# create type x as ("aBc" integer);
CREATE TYPE
edgar=# select * from json_populate_recordset(null::x,{"abC" : 4}]');
 aBc
-----


   3

(4 rows)

如果您无法保证输入数据的大小写,则显示小写的所有内容.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐