產品介紹
什么是數環通
基礎概念講解
應用場景
多渠道數據融合
業務、財務、辦公自動化
產業鏈應用與數據集成
工業應用與設備互聯
智慧園區與未來社區
快速入門
創建LinkUp
應用授權
判斷用法
監控用法
分支用法
列表逐條處理
變量與表達式
流程管理
項目管理
流程創建
編輯器操作
單步測試與預覽
試運行
發布與版本管理
錯誤步驟重試
數據同步
JSON Path 使用
輸出處理
數據編排
1、功能使用手冊
2、腳本使用手冊
1 、簡單查詢
2、謂詞查詢
3、函數與表達式
4、構建結構結果
5、查詢組合
6、排序、分組和聚合
7、處理模型
8、函數式編程
9、正則表達式
10、日期、時間處理
11、路徑運算符
12、數字運算符
13、比較運算符
14、布爾運算符
15、其他運算符
16、字符串函數
17、數值函數
18、 數字聚合函數
19、布爾函數
20、數組函數
21、對象函數
22、日期/時間函數
23、高階函數
運行日志
運行記錄
開發工具
連接器工具
連接器源碼配置
控件類型配置
腳本配置說明
內置函數
應用講解
內置應用
瀏覽器插件
數據表
文本字符串
日期
數據篩選
數據處理
延時處理
數學計算器
定時觸發器
子流程調用
手動觸發器
物流地址解析
腳本執行器
自定義變量
文件讀取
Webhook
SMTP發送郵件
文件傳輸
JSON工具
網絡工具
消息處理
PDF水印工具
文件存儲
API服務
Http請求
循環控制
EDI 自定義標準數據轉換
對象類型判斷
瀏覽器操作
三方應用
簡道云
金山數據表
抖音
釘釘(自建應用)
語雀
金山表單
微信公眾號
企業微信群機器人
聚水潭
企業微信三方授權
MySQL
SqlServer
ChatGpt
快手
金山輕維表
抖店
維格表
巨量千川
飛書多維表
釘釘機器人
飛書(自建)
釘釘
百度網盤
QQ郵箱
金山工作表
易知微DTable
MQTT
Doirs
中通快遞
韻達速遞
企業微信(代開發)
知乎效果營銷平臺
飛書云文檔
騰訊企業郵箱
API管理
API管理概述
數據概覽
API服務
訪問憑證
API門戶
API安全密鑰簽名
API監控預警
擴展工具
代理網關
消息處理
管理中心
企業管理
操作日志
成員管理
開放平臺
開放平臺簡介
接入教程
常見問題
數環通ip白名單
最佳實踐
彥祖文化 |通過數環通實現全渠道數據融合打通
新石器|通過數環通實現跨系統、跨部門高效協同
幫助首頁
數據編排
2、腳本使用手冊
6、排序、分組和聚合
6、排序、分組和聚合
# 排序、分組和聚合 ## 排序 數組包含有序的值集合。如果需要重新排序值,則必須對數組進行排序。在 JSONata 中,有兩種對數組進行排序的方法: 1. 使用該[`$sort()`]()函數。 2. 使用[order-by]()運算符。 order [-by]()運算符是一種方便的語法,可直接在路徑表達式中使用,按升序或降序對結果序列進行排序。該[`$sort()`]()函數需要編寫更多語法,但更靈活,并支持自定義比較器函數。 ## 分組 JSONata[對象構造]()函數語法允許您為任何鍵/值對中的鍵指定表達式(值顯然也可以是表達式)。鍵表達式必須求值為字符串,因為這是對 JSON 對象的限制。鍵和值表達式針對輸入上下文中的每個項目進行求值(請參閱[處理模型]())。每個鍵/值表達式對的結果都會插入到生成的 JSON 對象中。 如果對任何鍵表達式的求值得出的結果已存在于結果對象中,則其關聯值表達式的結果將與已與該鍵關聯的值分組。請注意,只有在完成所有分組后才會對值表達式進行求值。這樣就可以對每個組的項目集合求值聚合表達式。 **示例** * 將所有產品銷售按名稱分組,每組包含每件產品的價格 ``` Account.Order.Product{`Product Name`: Price} // 結果 { "Bowler Hat": [ 34.45, 34.45 ], "Trilby hat": 21.67, "Cloak": 107.99 } ``` * 將所有產品銷售按名稱分組,每組包含每件產品的價格和數量 ``` Account.Order.Product { `Product Name`: {"Price": Price, "Qty": Quantity} } // 結果 { "Bowler Hat": { "Price": [ 34.45, 34.45 ], "Qty": [ 2, 4 ] }, "Trilby hat": { "Price": 21.67, "Qty": 1 }, "Cloak": { "Price": 107.99, "Qty": 1 } } ``` 請注意,在上面的例子中,值表達式將所有價格組合在一起,將所有數量組合在一起,放入單獨的數組中。這是因為上下文值是所有分組產品的序列,而表達式 `Price` 將從所有產品中選擇所有價格。如果您想將價格和數量收集到單獨的對象中,則需要評估上下文序列中*每個產品的*對象構造函數。以下示例顯示了這一點。 * 明確使用為 `$.{ ... }` 組中的每個項目創建一個對象。 ``` Account.Order.Product { `Product Name`: $.{"Price": Price, "Qty": Quantity} } // 結果 { "Bowler Hat": [ { "Price": 34.45, "Qty": 2 }, { "Price": 34.45, "Qty": 4 } ], "Trilby hat": { "Price": 21.67, "Qty": 1 }, "Cloak": { "Price": 107.99, "Qty": 1 } } ``` * 將每組中每種產品的價格乘以數量 ``` Account.Order.Product{ `Product Name`: $.(Price*Quantity) } //結果 { "Bowler Hat": [ 68.9, 137.8 ], "Trilby hat": 21.67, "Cloak": 107.99 } ``` * 每組的總聚合值 ``` Account.Order.Product{`Product Name`: $sum($.(Price*Quantity))} //結果 { "Bowler Hat": 206.7, "Trilby hat": 21.67, "Cloak": 107.99 } ``` ## 聚合 通常,查詢僅需要從一組匹配值返回聚合結果。有許多聚合函數可用,當應用于一組值時,它們會返回單個聚合值。 **示例** * 每筆訂單中每件產品的總價 ``` $sum(Account.Order.Product.Price) // 結果 198.56 ``` * 更有可能的是希望將每份訂單的價格乘以數量相加 ``` $sum(Account.Order.Product.(Price*Quantity)) //結果 336.36 ``` 還有其他[數字聚合函數]()可用(即平均值、最小值、最大值)和[字符串聚合器]()。還可以使用[`$reduce()`]()高階函數編寫復雜的自定義聚合器。
上一篇
5、查詢組合
下一篇
7、處理模型
手機掃碼
復制鏈接
手機掃一掃轉發分享
復制鏈接
Markdown文件
分享
鏈接
類型
密碼
更新密碼
主站蜘蛛池模板:
色在线视频网站
|
国产高清精品久久久久久久
|
精品午夜视频
|
国产爆操
|
欧美性色视频
|
国产成人综合手机在线播放
|
日韩一区在线视频
|
国产成人一区二区三区影院免费
|
久久国产高清视频
|
欧美视频中文字幕
|
久久成人免费视频
|
五月天激情综合小说专区
|
99精品久久99久久久久
|
欧美 日韩 中文
|
免费视频一区二区三区四区
|
欧美一区二区三区性
|
久久亚洲精品人成综合网
|
999福利视频
|
国产综合精品久久亚洲
|
99精品国产成人一区二区在线
|
国产精品免费网站
|
久久只有这里的精品69
|
色戒电影视频
|
久久亚洲网站
|
欧美成人免费网站
|
六月丁香网
|
成人亚洲视频
|
国产精品一区二区四区
|
久久人人爽人人爽人人片669
|
精品无码久久久久国产
|
国语视频在线观看免费
|
婷婷丁香亚洲
|
精品国产一区二区三区成人
|
sw137
|
久久婷婷五色综合夜啪
|
五月天婷婷精品视频
|
久久99精品综合国产首页
|
99精品久久99久久久久久
|
漂亮的保姆完整版免费韩剧
|
色偷偷久久一区二区三区
|
人成电影网在线观看免费
|