Xmas__
Xmas__
采纳率0%
2021-05-04 20:38

Postgresql 如何在自定义函数中将查到的数据写入字符串数组中

pg萌新求教

从表中取三个不同的character varying类型的数据,如何插入字符串数组中

上代码

create or replace function bus_transfer_only() 
returns character varying as $$

declare i integer;
		j integer;
		d integer;
		frog integer;
		res_gid1 character varying(24)[];
		res_puid1 character varying(24)[];
		res_luid1 character varying(24)[];
		res_gid2 character varying(24)[];
		res_puid2 character varying(24)[];
		res_luid2 character varying(24)[];
begin 
	i := 0;
	j := 0;
	frog := 0;
execute 
	'select t.gid, t.pointuid, t.lineuid  
	from dalian_bus_point t
	where 
		st_distanceSphere(
		    st_setsrid(geom,4326),
			ST_GeometryFromText(''point(121.533143938637 38.891021094920)'',4326)) <=2500
	order by 
		ST_DistanceSphere(
            geom,
            ST_GeometryFromText(''point(121.533143938637 38.891021094920)'',4326)) 
	limit 150' into res_gid1, res_puid1, res_luid1;

execute
	'select t.*, 
	from dalian_bus_point t
	where 
		st_distanceSphere(
	       st_setsrid(geom,4326),
		   ST_GeometryFromText(''point(121.628355729643 38.9211884963126)'',4326)) <=1500
	order by 
		ST_DistanceSphere(
            geom,
            ST_GeometryFromText(''point(121.628355729643 38.9211884963126)'',4326)) 
	limit 150' into res_gid2, res_puid2, res_luid2;

因为 limit 150 所以我这样写肯定不对,但是我也不知道其他办法

还有如果以上查询有效率更高的写法,也欢迎贴出来一起学习

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

3条回答

  • technologist_32 CSDN技术专家团-The Last Time 4天前

    尽量不要在Order by后面有转换函数,会导致查询效率低。

    点赞 评论 复制链接分享
  • QA_Assistant 有问必答小助手 昨天

    非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

    速戳参与调研>>>https://t.csdnimg.cn/Kf0y

    点赞 评论 复制链接分享
  • QA_Assistant 有问必答小助手 2天前

    您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

    如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

    ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

    点赞 评论 复制链接分享

相关推荐