日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

【SQL编程】Greenplum 实现树结构+自定义函数+避免函数重复调用+ function cannot execute on a QE slice 问题处理(优化过程全记录)

發布時間:2024/10/6 数据库 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【SQL编程】Greenplum 实现树结构+自定义函数+避免函数重复调用+ function cannot execute on a QE slice 问题处理(优化过程全记录) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.需求說明

這是一個關于POI的應用,數據從水經微圖下載而來,需要處理的是街道層級的數據,但是最終的POI信息要有省、市、縣數據,所有需要用到行政區劃表來補全數據。

2.編程實例

2.1 實現樹結構

首先看一下具有樹結構的數據:


通過 WITH RECURSIVE table_name AS 實現遞歸查詢樹結構數據【這里要特別注意一下 t0 和 t1 表】:

WITH RECURSIVE t1 AS (SELECT "level", parent_code, area_code, "name" FROM data_divisions WHERE "name" = '楓楊街道' UNION ALLSELECT t0."level", t0.parent_code, t0.area_code, t0."name" FROM data_divisions t0, t1 WHERE t0.area_code = t1.parent_code ) SELECT "level", "name" FROM t1

結果驗證:

2.2 自定義函數

使用STRING_AGG把省市縣數據拼接成一個字段【函數等價于GROUP_CONCAT】:

SELECTSTRING_AGG ( "name", ',' ORDER BY "level" ) AS "divisions" FROM ( WITH RECURSIVE t1 AS (SELECT "level", parent_code, area_code, "name" FROM data_divisions WHERE "name" = '楓楊街道' UNION ALLSELECT t0."level", t0.parent_code, t0.area_code, t0."name" FROM data_divisions t0, t1 WHERE t0.area_code = t1.parent_code ) SELECT "level", "name" FROM t1 ) t2

創建自定義函數:

CREATE OR REPLACE FUNCTION getdivisionsbyname ( TEXT ) RETURNS TEXT AS $BODY$ SELECTSTRING_AGG ( "name", ',' ORDER BY "level" ) AS "divisions" FROM ( WITH RECURSIVE t1 AS (SELECT "level", parent_code, area_code, "name" FROM data_divisions WHERE "name" = '楓楊街道' UNION ALLSELECT t0."level", t0.parent_code, t0.area_code, t0."name" FROM data_divisions t0, t1 WHERE t0.area_code = t1.parent_code ) SELECT "level", "name" FROM t1 ) t2;$BODY$ LANGUAGE SQL IMMUTABLE STRICT COST 100;

函數調用測試:

SELECT getDivisionsByName('楓楊街道');

2.3 函數使用

data_address_point 表的記錄數是261條,執行耗時119.451s,這效率明顯是由于多次調用自定義函數導致的 😢

SELECT getdivisionsbyname(zone_name) || NAME AS "poi",SPLIT_PART( coordinates, ',', 1 ) AS "longitude",SPLIT_PART( coordinates, ',', 2 ) AS "latitude",NAME AS "address",SPLIT_PART( getdivisionsbyname(zone_name), ',', 1 ) AS "prov",SPLIT_PART( getdivisionsbyname(zone_name), ',', 2 ) AS "city",SPLIT_PART( getdivisionsbyname(zone_name), ',', 3 ) AS "district",SPLIT_PART( getdivisionsbyname(zone_name), ',', 4 ) AS "town" FROM data_address_point;


避免多次調用相同的自定義函數,優化后耗時23.634s,是之前的5分之1:

WITH t1 AS ( SELECT getdivisionsbyname ( zone_name ) AS "divisions", coordinates, "name", poi_type FROM data_address_point ) SELECT ROW_NUMBER ( ) OVER ( ORDER BY "name" ) AS "id", REPLACE ( divisions, ',', '' ) || "name" AS "poi", poi_type, SPLIT_PART( coordinates, ',', 1 ) AS "longitude", SPLIT_PART( coordinates, ',', 2 ) AS "latitude", NAME AS "address", SPLIT_PART( divisions, ',', 1 ) AS "prov", SPLIT_PART( divisions, ',', 2 ) AS "city", SPLIT_PART( divisions, ',', 3 ) AS "district", SPLIT_PART( divisions, ',', 4 ) AS "town" FROMt1

3.報錯問題

實際上,上邊的函數使用并是非順利的,第一次進行查詢時報錯function cannot execute on a QE slice because it accesses relation

WITH t1 AS ( SELECT getdivisionsbyname ( zone_name ) AS "divisions", coordinates, "name", poi_type FROM data_address_point ) SELECT ROW_NUMBER ( ) OVER ( ORDER BY "name" ) AS "id", REPLACE ( divisions, ',', '' ) || "name" AS "poi", poi_type, SPLIT_PART( coordinates, ',', 1 ) AS "longitude", SPLIT_PART( coordinates, ',', 2 ) AS "latitude", NAME AS "address", SPLIT_PART( divisions, ',', 1 ) AS "prov", SPLIT_PART( divisions, ',', 2 ) AS "city", SPLIT_PART( divisions, ',', 3 ) AS "district", SPLIT_PART( divisions, ',', 4 ) AS "town" FROMt1 > ERROR: function cannot execute on a QE slice because it accesses relation "public.data_divisions" (seg0 slice1 192.168.0.123:6000 pid=168995) CONTEXT: SQL function "getdivisionsbyname" during startup

UDF(User Defined Function)用戶自定義函數在 segment 上不能訪問任何表。由于 MPP 的特性,任何 segment 僅僅包含部分數據,因而在 segment 執行的 UDF 不能訪問任何表,否則數據計算錯誤。Greenplum 支持另一種分布策略:復制表,即整張表在每個節點上都有一個完整的拷貝??墒褂靡韵旅钸M行設置:

ALTER TABLE table_name SET DISTRIBUTED REPLICATED;

數據量大的表不適合使用復制表模式,一些不經常變動的數據量比較小的比如碼表可以使用DISTRIBUTED REPLICATED模式,查詢性能也會有明顯的提升。

總結

以上是生活随笔為你收集整理的【SQL编程】Greenplum 实现树结构+自定义函数+避免函数重复调用+ function cannot execute on a QE slice 问题处理(优化过程全记录)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 总受合集lunjian双性h | 欧洲一区二区视频 | 亚洲黄色中文字幕 | 亚洲人一区二区三区 | 伦理久久| 亚洲av无码乱码在线观看性色 | 国产成人精品一区二区在线小狼 | 中文字幕一区二区三区门四区五区 | 久久国产精品精品国产色婷婷 | 日韩乱码在线 | 一级黄色毛毛片 | 国产色在线,com | 美女张开腿让男人桶爽 | 亚洲精视频 | 天天操夜夜操视频 | 日本国产网站 | 在线观看一区 | av大片网址 | 麻豆免费观看网站 | 最好看的mv中文字幕国语电影 | 国产精品成人免费精品自在线观看 | 亚洲av永久一区二区三区蜜桃 | 天天操天天干天天 | 五月婷婷激情 | 美女下部无遮挡 | 日韩在线不卡视频 | www亚洲成人 | 亚洲精品无码久久久久 | 国产精品无码999 | 日本一区二区三区久久 | 好色综合 | 久久精品免费播放 | 人妻少妇偷人精品久久性色 | 人妻少妇精品中文字幕av蜜桃 | 欧美变态另类刺激 | 久久久免费精品 | 国产小视频91 | 先锋影音av在线 | 不用播放器的av网站 | 在线观看亚洲 | 日韩精品啪啪 | 欧美黄频| 欧美激情18p| 先锋成人| 秋霞99| www插插插无码免费视频网站 | 日韩av线观看| 大桥未久av一区二区三区中文 | 2020国产在线 | 日韩视频一区二区在线观看 | 激情综合啪啪 | 欧美老肥婆性猛交视频 | 大奶av | 欧美日韩一区二区三区在线 | 欧美一二三区视频 | 97色资源| 亚洲精品乱码久久久久久蜜桃91 | 又粗又猛又爽又黄少妇视频网站 | 亚洲GV成人无码久久精品 | 丰满熟妇肥白一区二区在线 | 国产精品成人久久久久久久 | 精品久久久久中文慕人妻 | 色香av | 蜜臀av性久久久久蜜臀av麻豆 | 欧美一级黄色大片 | 高清成人 | 91丝袜呻吟高潮美腿白嫩 | 高清毛片aaaaaaaaa片 | av午夜影院 | 国产精品乱码妇女bbbb | 超碰免费av | 无码精品在线观看 | 四虎影院色 | 国产色a | 蜜桃一区二区三区 | 最新av中文字幕 | 日本动漫艳母 | 国产 福利 在线 | 亚洲熟妇一区二区 | 视频在线a | 熟妇高潮一区二区三区 | 欧洲视频一区二区 | 亚洲成人av电影 | 国产欧美一区二区精品性色超碰 | 国产高中女学生第一次 | 好吊色一区二区 | 一本一道精品欧美中文字幕 | 激情丁香网| 日本无遮挡边做边爱边摸 | 巨乳女教师的诱惑 | 国产精品免费一区二区 | 久久靠逼视频 | 色噜噜狠狠一区二区三区果冻 | 91av一区 | 国产va视频| 理论黄色片| 在线免费成人网 | 国产精品xxxx喷水欧美 | 精品在线小视频 |