婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 對Postgresql中的json和array使用介紹

對Postgresql中的json和array使用介紹

熱門標簽:天津開發區地圖標注app 電銷機器人能補救房產中介嗎 400電話申請客服 江蘇400電話辦理官方 電話機器人怎么換人工座席 廣州電銷機器人公司招聘 地圖標注要花多少錢 濟南外呼網絡電話線路 移動外呼系統模擬題

結合近期接觸到的知識點,做了一個歸納。會持續更新

json

官網文檔 http://www.postgres.cn/docs/12/datatype-json.html

json的兩種格式

總結:json輸入快,處理慢。是精準拷貝,所以能準確存儲遺留對象的原格式,如對象鍵順序。jsonb輸入慢,處理快。會被重新解析成json數據,不保存原對象的鍵順序,并且去重相同的鍵值,以最后一個為準。通常,除非有特別特殊的需要(例如遺留的對象鍵順序假設),大多數應用應該 更愿意把 JSON 數據存儲為jsonb

官網:

json 和 jsonb數據類型接受***幾乎***完全相同的值集合作為輸入。 主要的實際區別之一是效率。json數據類型存儲輸入文本的精準拷貝,處理函數必須在每 次執行時必須重新解析該數據。而jsonb數據被存儲在一種分解好的 二進制格式中,它在輸入時要稍慢一些,因為需要做附加的轉換。但是 jsonb在處理時要快很多,因為不需要解析。jsonb也支 持索引,這也是一個令人矚目的優勢。

由于json類型存儲的是輸入文本的準確拷貝,其中可能會保留在語法 上不明顯的、存在于記號之間的空格,還有 JSON 對象內部的鍵的順序。還有, 如果一個值中的 JSON 對象包含同一個鍵超過一次,所有的鍵/值對都會被保留( 處理函數會把最后的值當作有效值)。相反,jsonb不保留空格、不 保留對象鍵的順序并且不保留重復的對象鍵。如果在輸入中指定了重復的鍵,只有 最后一個值會被保留。

通常,除非有特別特殊的需要(例如遺留的對象鍵順序假設),大多數應用應該 更愿意把 JSON 數據存儲為jsonb

由于json類型存儲的是輸入文本的準確拷貝,其中可能會保留在語法 上不明顯的、存在于記號之間的空格,還有 JSON 對象內部的鍵的順序。還有, 如果一個值中的 JSON 對象包含同一個鍵超過一次,所有的鍵/值對都會被保留( 處理函數會把最后的值當作有效值)。相反,jsonb不保留空格、不 保留對象鍵的順序并且不保留重復的對象鍵。如果在輸入中指定了重復的鍵,只有 最后一個值會被保留。

-----------1.鍵的順序
SELECT '{"bar": "baz", "balance": 7.77, "active":false}'::json;
           json            
-------------------------------------------------
 {"bar": "baz", "balance": 7.77, "active":false}
(1 row)
SELECT '{"bar": "baz", "balance": 7.77, "active":false}'::jsonb;
           jsonb            
--------------------------------------------------
 {"bar": "baz", "active": false, "balance": 7.77}
(1 row)
---------2.去重
SELECT '{"bar": "baz", "balance": 7.77, "balance":false}'::jsonb; --去重
{"bar": "baz", "balance": false}
SELECT '{"bar": "baz", "balance": 7.77, "balance":false}'::json; --不去重
{"bar": "baz", "balance": 7.77, "balance":false}
select '[1, 2, 2]'::jsonb --數組不去重
[1, 2, 2]

將字符串轉為json格式

sq-- 簡單標量/基本值
-- 基本值可以是數字、帶引號的字符串、true、false或者null
SELECT '5'::json;
-- 有零個或者更多元素的數組(元素不需要為同一類型)
SELECT '[1, 2, "foo", null]'::json;
-- 包含鍵值對的對象
-- 注意對象鍵必須總是帶引號的字符串
SELECT '{"bar": "baz", "balance": 7.77, "active": false}'::json;
-- 數組和對象可以被任意嵌套
SELECT '{"foo": [true, "bar"], "tags": {"a": 1, "b": null}}'::json;

輸出:

5
[1, 2, “foo”, null]
{“bar”: “baz”, “balance”: 7.77, “active”: false}
{“foo”: [true, “bar”], “tags”: {“a”: 1, “b”: null}}

判斷是否包含/存在 @> 和 ?

-- 簡單的標量/基本值只包含相同的值:
SELECT '"foo"'::jsonb @> '"foo"'::jsonb; --得 真t
-- 右邊的數字被包含在左邊的數組中:
SELECT '[1, 2, 3]'::jsonb @> '[1, 3]'::jsonb; --t 
-- 數組元素的順序沒有意義,因此這個例子也返回真:
SELECT '[1, 2, 3]'::jsonb @> '[3, 1]'::jsonb; --t
-- 重復的數組元素也沒有關系:
SELECT '[1, 2, 3]'::jsonb @> '[1, 2, 2]'::jsonb; --t
-- 右邊具有一個單一鍵值對的對象被包含在左邊的對象中:
SELECT '{"product": "PostgreSQL", "version": 9.4, "jsonb": true}'::jsonb @> '{"version": 9.4}'::jsonb; --t

jsonb還有一個存在操作符,它是包含的一種 變體:它測試一個字符串(以一個text值的形式給出)是否出 現在jsonb值頂層的一個對象鍵或者數組元素中。

除非特別注解, 下面這些例子返回真:

-- 字符串作為一個數組元素存在:
SELECT '["foo", "bar", "baz"]'::jsonb ? 'bar'; --t
-- 字符串作為一個對象鍵存在:
SELECT '{"foo": "bar"}'::jsonb ? 'foo'; --t
-- 不考慮對象值:
SELECT '{"foo": "bar"}'::jsonb ? 'bar'; -- 得到假

當涉及很多鍵或元素時,JSON 對象比數組更適合于做包含或存在測試, 因為它們不像數組,進行搜索時會進行內部優化,并且不需要被線性搜索。

索引

-> 數組中是查找第幾項,json中是取某key的元素object
->> json中是取某key的元素text
#>  json中是通過路徑取元素object
#>>  json中是通過路徑取元素text
json:='[{"a":"foo"},{"b":"bar"},{"c":"baz"}]'::json
--獲取json數組中的某一項元素
--下標從0開始
select json->2 from test where name='jsonarray' --{"c": "baz"}
--獲取json某一key的值為object
select (json->2)->'c' from test where name='jsonarray' --"baz"
--獲取json某一key的值為text
select (json->2)->>'c' from test where name='jsonarray' --"baz"
--獲取json某值通過路徑 object
 '{"a": {"b":{"c": "foo"}}}'::json#>'{a,b}' --{"c": "foo"}
--獲取json某值通過路徑 text
 '{"a":[1,2,3],"b":[4,5,6]}'::json#>>'{a,2}' --3

補充:postgresql 數據庫 jsonb/json中 array或int 類型進行的交集比較 存儲過程字符串、整數數組條件查詢

首先要新增這兩個存儲過程

新增存儲過程字符串數組條件查詢

CREATE OR REPLACE FUNCTION json_arr2text_arr(_js json) RETURNS text[] AS
$$
DECLARE
 anyArray text[];
begin
SELECT ARRAY(SELECT json_array_elements_text(_js)) INTO anyArray;
RETURN anyArray;
end
$$ 
LANGUAGE plpgsql;

查詢字符串數組中存在NP1的記錄

select * from tb_template_area_safe WHERE json_arr2text_arr(area_functions) @> array['NP1'];

新增存儲過程整數數組條件查詢

CREATE OR REPLACE FUNCTION json_arr2int_arr(_js json) RETURNS int[] AS 
$$
DECLARE
 anyArray int[];
begin
SELECT ARRAY(SELECT json_array_elements_text(_js)::int) INTO anyArray;
RETURN anyArray;
end;
$$ 
LANGUAGE plpgsql;

查詢條件是 左面 的 包含右面的

兩者的交集

SELECT tdnm.mid, tdnm.title, tdnm.content, tdnm.ui_id, tdnm.create_time, tdnm.cancel_time, 
tdnm.job_ids, tdnm.remarks, tdnm.message_level_code, tdnm.channels FROM tb_data_notify_message 
tdnm WHERE 1=1 and json_arr2text_arr(tdnm.job_ids) 
array[['1','10']] ORDER BY create_time DESC
 

數組操作符:

Operator Description Example Result
= equal ARRAY[1.1,2.1,3.1]::int[] = ARRAY[1,2,3] t
> not equal ARRAY[1,2,3] > ARRAY[1,2,4] t
less than ARRAY[1,2,3] ARRAY[1,2,4] t
> greater than ARRAY[1,4,3] > ARRAY[1,2,4] t
= less than or equal ARRAY[1,2,3] = ARRAY[1,2,3] t
>= greater than or equal ARRAY[1,4,3] >= ARRAY[1,4,3] t
@> contains ARRAY[1,4,3] @> ARRAY[3,1] t
@ is contained by ARRAY[2,7] @ ARRAY[1,7,4,2,6] t
overlap (have elements in common) ARRAY[1,4,3] ARRAY[2,1] t
|| array-to-array concatenation ARRAY[1,2,3] || ARRAY[4,5,6] {1,2,3,4,5,6}
|| array-to-array concatenation ARRAY[1,2,3] || ARRAY[[4,5,6],[7,8,9]] {{1,2,3},{4,5,6},{7,8,9}}
|| element-to-array concatenation 3 || ARRAY[4,5,6] {3,4,5,6}
|| array-to-element concatenation ARRAY[4,5,6] || 7 {4,5,6,7}

PostgreSQL 9.4.4 中文手冊

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 解決PostgreSQL Array使用中的一些小問題
  • postgresql數據庫使用說明_實現時間范圍查詢
  • postgresql 實現將數組變為行
  • PostgreSQL 對數組的遍歷操作
  • postgres array_to_string和array的用法講解

標簽:溫州 辛集 海西 昭通 杭州 寶雞 濮陽 榆林

巨人網絡通訊聲明:本文標題《對Postgresql中的json和array使用介紹》,本文關鍵詞  對,Postgresql,中的,json,和,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《對Postgresql中的json和array使用介紹》相關的同類信息!
  • 本頁收集關于對Postgresql中的json和array使用介紹的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲欧洲精品天堂一级| 亚洲视频在线一区观看| 久久精品欧美日韩| 午夜精品福利一区二区蜜股av| 免费视频最近日韩| 91啪亚洲精品| 国产精品免费av| 国产成人精品免费在线| 国产视频一区不卡| caoporn国产精品| 欧美一区二区三区性视频| 欧美刺激脚交jootjob| 美国欧美日韩国产在线播放| 欧美喷水一区二区| 午夜不卡av在线| 精品国产免费一区二区三区四区| 日韩精品一卡二卡三卡四卡无卡| 国产不卡高清在线观看视频| 国产日韩欧美a| 成人一区二区视频| 亚洲国产精品成人综合 | 成人午夜电影小说| 国产精品国产a级| 国产v综合v亚洲欧| 一区二区三区在线视频播放| 色8久久人人97超碰香蕉987| 亚洲三级在线看| 欧美日韩一区视频| 国产福利一区在线| 玉米视频成人免费看| 欧美精品一区二区三区很污很色的 | 在线综合视频播放| 日韩av高清在线观看| 国产精品乱人伦中文| 日韩精品一区二区三区中文精品 | 日韩欧美一区在线| www.欧美日韩| 国产综合成人久久大片91| 一区二区三区四区在线| 欧美激情自拍偷拍| 久久久99精品久久| 欧美电影免费观看高清完整版| 日韩在线一二三区| 亚洲色欲色欲www在线观看| 久久久久久久久久久99999| 欧美日韩专区在线| 欧美日本一区二区三区| 色噜噜狠狠成人中文综合| 国产精品77777| 国产精品白丝jk黑袜喷水| 老司机午夜精品99久久| 日韩精品一二三区| 久久精品国产亚洲a| 国产一区二区三区精品视频| 久久99九九99精品| 国产成人在线视频网站| 成人av网站免费观看| 成人免费精品视频| 欧美又粗又大又爽| 日韩一区二区电影在线| 欧美va亚洲va| 国产精品你懂的| 亚洲第一福利一区| 美腿丝袜亚洲色图| 国产盗摄一区二区| 91丨九色丨尤物| 欧美一区日韩一区| 国产精品传媒视频| 亚洲国产aⅴ成人精品无吗| 麻豆精品一区二区三区| 99re在线视频这里只有精品| 欧美另类z0zxhd电影| 久久久久亚洲蜜桃| 亚洲不卡在线观看| 成人小视频免费观看| 色哟哟国产精品| 欧美精品一区二区三区一线天视频 | 成人深夜视频在线观看| 欧美日韩视频专区在线播放| 一本色道亚洲精品aⅴ| 欧美日韩日日骚| 亚洲欧美综合色| 欧美日韩免费高清一区色橹橹| 精品视频一区 二区 三区| 久久久五月婷婷| 久久国产精品露脸对白| 9191成人精品久久| 午夜激情一区二区三区| 色呦呦日韩精品| 综合色天天鬼久久鬼色| 国产二区国产一区在线观看| 久久久美女毛片| 国产乱人伦偷精品视频免下载| 91精品国产91热久久久做人人| 亚洲免费观看高清完整版在线观看熊| 久久精品国产免费| 一区二区高清视频在线观看| 成人深夜视频在线观看| 综合欧美亚洲日本| 99re热这里只有精品免费视频| 国产精品乱码一区二区三区软件| 不卡影院免费观看| 亚洲自拍另类综合| 欧美一区二区成人| 国产在线一区观看| 成人欧美一区二区三区1314| 91浏览器打开| 日本视频一区二区| 国产亚洲一本大道中文在线| 国产91在线|亚洲| 亚洲国产cao| 久久久精品免费观看| 97国产一区二区| 久久精工是国产品牌吗| 国产精品传媒视频| 日韩你懂的在线播放| 色又黄又爽网站www久久| 亚洲小少妇裸体bbw| 国产视频一区二区在线| 在线成人高清不卡| 91官网在线观看| 国产美女av一区二区三区| 国产精品乱码久久久久久| 欧美本精品男人aⅴ天堂| 精品视频在线免费看| 成人深夜视频在线观看| 国产二区国产一区在线观看| 免费在线视频一区| 夜夜操天天操亚洲| 亚洲丝袜自拍清纯另类| 国产农村妇女精品| 日本一区二区久久| 国产午夜精品一区二区三区视频 | 亚洲激情网站免费观看| 精品国产一区二区精华| 欧美性色欧美a在线播放| 日本精品视频一区二区| 91视频在线看| 色悠悠亚洲一区二区| 色哟哟国产精品| 欧美偷拍一区二区| 欧美精品日韩精品| 日韩女优毛片在线| 2欧美一区二区三区在线观看视频| 91精品国产一区二区三区香蕉| 欧美绝品在线观看成人午夜影视| 欧美日韩一二三区| 欧美日韩中文字幕精品| 欧美高清性hdvideosex| 91精品国产美女浴室洗澡无遮挡| 欧美日韩国产综合一区二区| 欧美美女一区二区在线观看| 欧美日高清视频| 国产日韩精品一区二区三区| 亚洲国产精品二十页| 亚洲激情图片小说视频| 日韩av成人高清| 国产一区 二区 三区一级| 成人免费视频视频在线观看免费 | 精品一区二区久久| 国产精品1区2区| 欧美在线三级电影| 精品欧美一区二区在线观看| 日本一区二区三区国色天香 | 成人av网址在线| 日韩丝袜美女视频| 一区二区三区日韩精品视频| 精品一区二区三区在线观看| 在线观看欧美精品| 国产欧美日韩不卡| 视频在线观看一区| 欧美无人高清视频在线观看| 久久精品视频在线免费观看| 亚洲国产成人av好男人在线观看| 成人福利在线看| 国产人久久人人人人爽| 久久国产精品72免费观看| 欧美日韩国产经典色站一区二区三区| 国产精品久久久久久久第一福利| 奇米四色…亚洲| 日韩色视频在线观看| 日日骚欧美日韩| 欧美色中文字幕| 亚洲宅男天堂在线观看无病毒| 91亚洲精品一区二区乱码| 精品成人免费观看| 精品夜夜嗨av一区二区三区| 日韩欧美的一区二区| 久久99精品国产麻豆不卡| 日韩亚洲欧美高清| 国产综合色视频| 国产精品欧美经典| 色婷婷国产精品| 日韩成人免费电影| 久久久99精品久久| 99re热视频这里只精品| 亚洲高清久久久| 精品国产一区二区三区久久影院 | 久久精品亚洲精品国产欧美| a美女胸又www黄视频久久|