加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql 搜索指定距离内的记录 按近到远排序 并返回距离

发布时间:2020-12-13 17:01:13 所属栏目:百科 来源:网络整理
导读:脚本 CREATE TABLE mylocation ( id SERIAL PRIMARY KEY,geom GEOMETRY(Point,4326),name VARCHAR(128),x double precision,y double precision); INSERT INTO mylocation (geom,name,x,y) VALUES ( ST_GeomFromText('POINT(0.0001 0)','zhangsan',0.0001,0)

脚本


CREATE TABLE mylocation ( 
  id SERIAL PRIMARY KEY,geom GEOMETRY(Point,4326),name VARCHAR(128),x double precision,y double precision
); 
 
INSERT INTO mylocation (geom,name,x,y) VALUES (
  ST_GeomFromText('POINT(0.0001 0)','zhangsan',0.0001,0
);
INSERT INTO mylocation (geom,y) VALUES (
  ST_GeomFromText('POINT(0.001 0)',0.001,y) VALUES (
  ST_GeomFromText('POINT(0.1 0)',0.1,0
);



SELECT id,geom,y,ST_DistanceSphere(
                      geom,ST_GeometryFromText('POINT(0 0)')) distance
FROM mylocation
WHERE ST_DWithin(
  geom,ST_GeomFromText('POINT(0 0)',0.001
)ORDER BY distance asc;;

查询语句 下面距离单位为m

SELECT id,ST_GeometryFromText('POINT(0 0)')) distance
FROM mylocation
WHERE ST_DWithin(
  geom::geography,4326)::geography,1000
) ORDER BY distance asc;


搜索结果

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读