用postgreSQL做基于地理位置的app

  次阅读 来源:互联网(转载协议) 2016-02-17 09:43 我要评论(0)

前言:项目中用到了postgreSQL中的earthdistance()函数功能计算地球上两点之间的距离,中文的资料太少了,我找到了一篇英文的、讲的很好的文章,特此翻译,希望能够帮助到以后用到earthdistance的同学。

一、两种可用的选择

当我们想用Postgres作为GEO函数使用时,我们通常有2中选择(据我所知):

1.PostGIS: 为postgreSQL提供了高级GEO函数功能。我用了它一段时间,但是它对于我的需求来说太笨重了。

2.Cube和Earthdistance: 这两个拓展为轻量级的Geo关系实体提供了简单、快速的实现方法。

二、为什么在数据库服务器端做计算

这是件非常明显的事。服务器存储了所有的数据,服务器拓展是用C/C++实现的,非常快。为数据表做索引也能加快计算速度。

三、使用我的选择--Cube and EarthDistance

作为开始,你应该先建一个数据库(我想你知道该怎么做),然后使它们能用我们的架构。 执行:

?

1

2

CREATE EXTENSION cube;

CREATE EXTENSIONearthdistance;

上面的命令创建了大约40个函数,以后我们做数据查询的时候就可以用了。

在我们的例子中,我创建了名为events的表,字段有:id(serial), name(varchar 255), lat(double),lng(double)。(别忘了~~)

四、计算2个坐标之间的距离

计算2个坐标之间的距离,我们要用到earth_distance(ll_to_earth($latlngcube),ll_to_earth($latlng_cube))这个函数。earth_distance()函数接受2组坐标值,返回值一个以米为单位的的数值。这能用于很多场景,比如根据某一位置找到离其最近的发生的新闻事件的列表。

【译者注】这里要提下几个重要的函数:(参考:http://www.postgresql.org/docs/8.3/static/earthdistance.html)

Table F-3. Cube-based earthdistance functions

Function

Returns

Description

earth()

float8

Returnsthe assumed radius of the Earth.

sec_to_gc(float8)

float8

Convertsthe normal straight line (secant) distance between between two points on thesurface of the Earth to the great circle distance between them.

gc_to_sec(float8)

float8

Convertsthe great circle distance between two points on the surface of the Earth to thenormal straight line (secant) distance between them.

ll_to_earth(float8,float8)

earth

Returnsthe location of a point on the surface of the Earth given its latitude (argument1) and longitude (argument 2) in degrees.

latitude(earth)

float8

Returnsthe latitude in degrees of a point on the surface of the Earth.

longitude(earth)

float8

Returnsthe longitude in degrees of a point on the surface of the Earth.

earth_distance(earth,earth)

float8

Returnsthe great circle distance between two points on the surface of theEarth.

earth_box(earth,float8)

cube

Returnsa box suitable for an indexed search using the cube @> operatorfor points within a given great circle distance of a location. Some points inthis box are further than the specified great circle distance from the location,so a second check using earth_distance should be included in thequery.

本站部分文章来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

    品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

  • 第一批国家重点研发计划公布,旷视科技开启“五年行动”

    第一批国家重点研发计划公布,旷视科技开启“五年行动”

  • 长虹新款智能语音空调,告诉你空调也能玩Siri

    长虹新款智能语音空调,告诉你空调也能玩Siri

  • 让AI触手可及  Qualcomm携手创通联达推出全新终端侧AI开发套件

    让AI触手可及 Qualcomm携手创通联达推出全新终端侧AI开发套件

网友点评网友点评
阅读推荐阅读推荐

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...