plpgsql 编程 - JSON数组循环

本文介绍如何使用PostgreSQL的PL/pgSQL编程语言来遍历JSON或JSONB类型的数组。通过两个示例展示了如何利用jsonb_array_elements和json_array_elements函数配合FOR循环来逐个处理数组中的每个JSON对象。

原文地址

 

标签

 

PostgreSQL , plpgsql , json , jsonb , array , 数组

背景

PostgreSQL的plpgsql编程语言和Oracle PL/SQL编程语言类似,是功能很强大的数据库编程语言。

JSON是PG支持的非结构化类型,那么如何在PLPGSQL中LOOP JSON数组呢?

https://www.postgresql.org/docs/9.6/static/plpgsql-control-structures.html#PLPGSQL-FOREACH-ARRAY

例子

例子1

postgres=# do language plpgsql $$  
declare  
  rec jsonb;  
begin  
  for rec in select jsonb_array_elements('[{"lat":30.27699965,"lng":120.02319424},{"lat":30.27700545,"lng":120.02321551}]')                     
  loop  
    raise notice '%', rec;  
  end loop;  
end;  
$$;  
NOTICE:  {"lat": 30.27699965, "lng": 120.02319424}  
NOTICE:  {"lat": 30.27700545, "lng": 120.02321551}  
DO  

例子2

DO  
$BODY$  
DECLARE  
    omgjson json := '[{ "type": false }, { "type": "photo" }, {"type": "comment" }]';  
    i json;  
BEGIN  
  FOR i IN SELECT * FROM json_array_elements(omgjson)  
  LOOP  
    RAISE NOTICE 'output from space %', i->>'type';  
  END LOOP;  
END;  
$BODY$ language plpgsql  

 

原文地址

转载于:https://my.oschina.net/u/3568122/blog/1501421

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值