在 PostgreSQL 9.2 版本中已经支持 JSON 类型,不过支持的操作非常有限,仅支持以下函数
 
array_to_json(anyarray [, pretty_bool])
row_to_json(record [, pretty_bool])
 
        如果想扩充 JSON 其它函数,得另外安装一些外部模块,好在 9.3 版本 JSON 增加了多种函数
和操作符,这增强了 JSON 的功能,接下来演示下。
 
一 JSON 操作符介绍
--1.1 创建 json 表并插入数据
 francs=> create table test_json1 (id serial primary key,name json);

CREATE TABLE
 
francs=> insert into test_json1 (name) values ('{"col1":1,"col2":"francs","col3":"male"}');
INSERT 0 1
francs=> insert into test_json1 (name) values ('{"col1":2,"col2":"fp","col3":"female"}');
INSERT 0 1
 
francs=> select * From test_json1;
 id |                   name                   
----+------------------------------------------
  1 | {"col1":1,"col2":"francs","col3":"male"}
  2 | {"col1":2,"col2":"fp","col3":"female"}
(2 rows)
 
francs=> create table test_1 (id int4,name varchar(32),flag char(1));
CREATE TABLE
 
francs=> insert into test_1 values (1,'a','f');
INSERT 0 1
francs=> insert into test_1 values (2,'b','f');
INSERT 0 1
francs=> insert into test_1 values (3,'c','t');
INSERT 0 1
 
francs=> select * from test_1;
 id | name | flag 
----+------+------
  1 | a    | f
  2 | b    | f
  3 | c    | t
(3 rows)

备注:创建两张测试表,其中第一张为 json 表。

 
--1.2 操作符 -> 介绍
 
          操作符 ->  可以返回 json 类型的字段值,例如:
 francs=> select id ,name ->'col1' col1, name -> 'col2' col2, name -> 'col3' col3 from test_json1 where id=1;

 id | col1 |   col2   |  col3  
----+------+----------+--------
  1 | 1    | "francs" | "male"
(1 row)
 
--1.3 操作符 ->> 介绍
 
        操作符 ->> 与之前的 -> 类似,只不过返回的是 text 类型,例如:
 francs=> select id ,name ->>'col1' col1, name ->> 'col2' col2, name ->> 'col3' col3 from test_json1 where id=1;

 id | col1 |  col2  | col3 
----+------+--------+------
  1 | 1    | francs | male
(1 row)
 
以上2个例子说明了json数据可以被以表的形式显示出来,这对于query的查询很有帮助,因为现在的开发语言都不是直接支持json的,所以到前台之后需要读取转换,这样很麻烦,有了这个函数前台的query就
直接可以用了,PQ帮你做好了一切
这里例1的返回结果是类型不变的结果,这里有个问题就是"":"" text类型 会返回带冒号的结果,这样在实际中可能会困扰,但是可以保持数据的原始类型,
对于个人而言,我的数据基本都是text类型,实际用的时候在转换,为了统一,而PQ也给力方案例2中就是以text输出的,这样text类型的冒号("")就没有了
 
--1.4  操作符 #> 介绍
    
      操作符 #> 返回 json 数据字段指定的元素,如下:
 francs=> select '{"a":[1,2,3],"b":[4,5,6]}'::json#>'{b,1}';

 ?column? 
----------
 5
(1 row)
 
francs=> select '{"a":[1,2,3],"b":[4,5,6]}'::json#>'{a,2}';
 ?column? 
----------
 3
(1 row)
这里我说一个扩展,可能我自己比较笨所以反反复复实验了,说下另外的应用
如以上例子中的表1中 用以上函数就可以查询制定的值
 select id ,name #> '{col2}' from test_json1 where id=1;

?column? 
----------
"francs"
同理,返回的是源类型,自己琢磨了下,可以返回text类型
select id ,name #>> '{col2}' from test_json1 where id=1;
?column? 
----------
francs
 
哈哈,很神奇
 
二 JSON 函数介绍
--2.1 json_each(json) 函数
 francs=> select * from test_json1 where id=1;

 id |                   name                   
----+------------------------------------------
  1 | {"col1":1,"col2":"francs","col3":"male"}
(1 row)
 
francs=> select * from json_each((select name from test_json1 where id=1));
 key  |  value   
------+----------
 col1 | 1
 col2 | "francs"
 col3 | "male"
(3 rows)
 
francs=> select * from json_each('{"a":"foo", "b":"bar"}');
 key | value 
-----+-------
 a   | "foo"
 b   | "bar"
(2 rows)
这个函数就是返回原始数据类型为一个表,可以看到text类型有""号 
--2.2 json_each_text(json) 函数
 francs=> select * from json_each_text((select name from test_json1 where id=1));

 key  | value  
------+--------
 col1 | 1
 col2 | francs
 col3 | male
(3 rows)
这个不用说了,返回text类型
 
--2.3 row_to_json 函数
 francs=> select row_to_json(test_1) from test_1;

          row_to_json           
--------------------------------
 {"id":1,"name":"a","flag":"f"}
 {"id":2,"name":"b","flag":"f"}
 {"id":3,"name":"c","flag":"t"}
(3 rows)
 
francs=> select row_to_json(test_1) from test_1 where id=1;
          row_to_json           
--------------------------------
 {"id":1,"name":"a","flag":"f"}
(1 row)
这个原来我只会as的方式,没想到可以这样
 
备注:这个函数在 9.2 就有,将结果集转换成 json,这里也记录下。
 
 
三 聚合函数 json_agg(record)
 
    最后介绍新增加的聚合函数 array_agg(record),此函数用来将结果集转换成 JSON 数组。
 
--3.1 例1
 francs=> alter table test_json1 add grade int4 default '6';

ALTER TABLE
 
francs=> select * from test_json1;
 id |                   name                   | grade 
----+------------------------------------------+-------
  1 | {"col1":1,"col2":"francs","col3":"male"} |     6
  2 | {"col1":2,"col2":"fp","col3":"female"}   |     6
(2 rows)
 
francs=> select json_agg(name) from test_json1 group by grade;
                                      json_agg                                      
------------------------------------------------------------------------------------
 [{"col1":1,"col2":"francs","col3":"male"}, {"col1":2,"col2":"fp","col3":"female"}]
(1 row)   

备注:结果很明显。

 
--3.2 例2
 francs=> select * from test_1;

 id | name | flag 
----+------+------
  1 | a    | f
  2 | b    | f
  3 | c    | t
(3 rows)
 
francs=> select json_agg(a) from test_1 a;
             json_agg              
-----------------------------------
 [{"id":1,"name":"a","flag":"f"}, +
  {"id":2,"name":"b","flag":"f"}, +
  {"id":3,"name":"c","flag":"t"}]
(1 row)
聚合函数就更牛牛逼了,以前row_to_json的时候基本都是只能一串一串输出,在用代码拼接,这下好了,PQ帮你直接连接起来,而且保证了数据绝对的准确性,同样也可以结合上面的符号
select json_agg(a) #>>'{0,name}' from test_1 a;
 
备注:JSON 函数还是比较复杂的,更多内容请参考手册。

PostgreSQL9.3:JSON 功能增强 根据PQ中文论坛francs 给出的东西结合自己的摸索总结下的更多相关文章

  1. Java SE 5.0 - SE 8 的功能增强

    Table of Contents 前言 Java 5.0 Generics Enhanced for Loop Autoboxing Typesafe Enums Varargs Static Im ...

  2. MWeb 1.4 新功能介绍二:静态博客功能增强

    MWeb 比较有特色的是一键生成静态博客功能,然后从 MWeb 最开始规划要做静态博客生成功能时,我就希望 MWeb 的静态博客生成功能在易用的同时,还要有很强大的扩展性. 比如说能自己增加网站公告, ...

  3. VMare中安装“功能增强工具”,实现CentOS5.5与win7host共享文件夹的创建

    读者如要转载,请标明出处和作者名,谢谢. 地址01:http://space.itpub.net/25851087 地址02:http://www.cnblogs.com/zjrodger/ 地址03 ...

  4. JSON取值(key是中文或者数字)方式详解

    JSON取值(key是中文或者数字)方式详解 先准备一个json对象用于演示 var json = {'name':'zhangsan', '年龄':23, 404:'你可能迷路了'}; 使用JS中w ...

  5. Android 使用JSON格式与服务器交互 中文乱码问题解决

    当前是在开发Android 程序时,客户端与服务器端采用JSON传送数据,发现中文乱码问题.不过这个问题的解决办法应该对所有java语言开发的项目都使用. 解决方法是: 1.客户端发送数据之间加上: ...

  6. jquery-7 jquery中的文档处理方法有哪些(方法的参数表示功能增强)

    jquery-7 jquery中的文档处理方法有哪些(方法的参数表示功能增强) 一.总结 一句话总结:多看参考文档,多看主干目录.一般的功能分两个方法来实现,一个对应标签,一个对应标签和事情,比如克隆 ...

  7. Apache 后台服务器(主要处理php及一些功能请求 如:中文url)   Nginx 前端服务器(利用它占用系统资源少得优势来处理静态页面大量请求)   Lighttpd 图片服务器   总体来说,随着nginx功能得完善将使他成为今后web server得主流。

    Apache 后台服务器(主要处理php及一些功能请求 如:中文url) Nginx 前端服务器(利用它占用系统资源少得优势来处理静态页面大量请求) Lighttpd 图片服务器 总体来说,随着ngi ...

  8. fastjson在将Map<Integer, String>转换成JSON字符串时,出现中文乱码问题

    fastjson在将Map<Integer, String>转换成JSON字符串时,出现中文乱码问题. 先记下这个坑,改天在看看是怎么导致的,暂时通过避免使用Integer作为键(使用St ...

  9. DevExpress WPF v19.1:Data Grid/Tree List等控件功能增强

    行业领先的.NET界面控件DevExpress 日前正式发布v19.1版本,本站将以连载的形式介绍各版本新增内容.在本系列文章中将为大家介绍DevExpress WPF v19.1中新增的一些控件及部 ...

随机推荐

  1. [HTTP] Understand 2xx HTTP Status Code Responses

    The 2xx family of status codes are used in HTTP responses to indicate success. Beyond the generic 20 ...

  2. 【Nutch2.2.1基础教程之3】Nutch2.2.1配置文件 分类: H3_NUTCH 2014-08-18 16:33 1376人阅读 评论(0) 收藏

    nutch-site.xml 在nutch2.2.1中,有两份配置文件:nutch-default.xml与nutch-site.xml. 其中前者是nutch自带的默认属性,一般情况下不要修改. 如 ...

  3. [CSS] Change the auto-placement behaviour of grid items with grid-auto-flow

    We can change the automatic behaviour of what order our grid items appear. We can even re-order the ...

  4. js如何使用正则表达式验证电话号码(可选区号)和邮箱?(分步骤)

    js如何使用正则表达式验证电话号码(可选区号)和邮箱?(分步骤) 一.总结 js进阶正则表达式16电话号码和邮箱正则(分类解决邮箱验证)(分组加?解决电话号码区号选择问题)([\w\.-]中括号解决邮 ...

  5. source insight 添加自定义macro

    打开C:\Documents and Settings\xxxx\My Documents\Source Insight\Projects\Base文件夹下的em文件,可以看到都是由macro定义的一 ...

  6. Android自定义控件View(一)

    虽然Android API给我们提供了众多控件View来使用,但是鉴于Android的开发性,自然少不了根据需求自定义控件View了.比如说QQ头像是圆形的,但是纵观整个Android控件也找不到一个 ...

  7. HTML中DOM对象的属性和方法的层级关系是怎样的?(目录即层次)

    HTML中DOM对象的属性和方法的层级关系是怎样的?(目录即层次) 一.总结 一句话总结:目录就是测试题 1.document取得元素(get element)的方式有哪几种? 解答:四种,分别是id ...

  8. hbase 判断列族是否存在

    public static boolean isExistColumnFamily(String tableName,String cf) throws IOException { if(isExis ...

  9. CentOS虚拟机克隆后IP设置

    1.网卡设置 vim /etc/udev/rules.d/70-persistent-net.rules 将新生成的eth1改名为eth0,并将原来的eth0注释或删除,同时复制mac地址 2.IP设 ...

  10. 入坑cordova

    原文:入坑cordova 因项目需要入坑cordova,奔跑吧骚年,目前只是要求安卓平台,下面都是以安卓为例 最好的学习资料还是官网. https://cordova.apache.org/ http ...