位置: 编程技术 - 正文

用PostgreSQL数据库做地理位置app应用

编辑:rootadmin

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

做一个GEO应用从来都不是一件容易的事。但是用一些身边的开源项目就可以在几分钟内轻松解决这个问题。 PostgreSQL有许多特性。是我的首选,它能够把数据库平台提升到另一个层次。

一、两种可用的选择

当我们想用Postgres作为GEO函数使用时,我们通常有2中选择(据我所知):PostGIS: 为postgreSQL提供了高级GEO函数功能。我用了它一段时间,但是它对于我的需求来说太笨重了。Cube和Earthdistance: 这两个拓展为轻量级的Geo关系实体提供了简单、快速的实现方法。

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

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

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

作为开始,你应该先建一个数据库(我想你知道该怎么做),然后使它们能用我们的架构。 执行: 然后执行: 上面的命令创建了大约个函数,以后我们做数据查询的时候就可以用了。在我们的例子中,我创建了名为events的表,字段有:id(serial), name(varchar ), lat(double), lng(double)。(别忘了~~)

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

计算2个坐标之间的距离,我们要用到 earthdistance(lltoearth($latlngcube), lltoearth($latlng_cube)) 这个函数。 earthdistance()函数接受2组坐标值,返回值一个以米为单位的的数值。

这能用于很多场景,比如根据某一位置找到离其最近的发生的新闻事件的列表。数据库的操作可能就像下面这样:这将给我们一个很nice的新闻事件列表,按他们的离我们当前位置的距离由近到远排序。第一个是离我们最近的。五、找到某个半径范围内的记录 Cube和Earthdiatance拓展提供的另一个伟大的函数是 earthbox(lltoearch($latlngcub), $radiusinmetres) 。 这个函数通过简单的比较就能到找到某个半径范围内的所有记录。它是靠返回2点之间的“大圆距离”实现的。

【译者注】大圆距离(Great circle disstance)指的是从球面的一点A出发到达球面上另一点B,所经过的最短路径的长度。一般说来,球面上任意两点A和B都可以与球心确定唯一的大圆,这个大圆被称为黎曼圆,而在大圆上连接这两点的较短的一条弧的长度就是大圆距离。如果想了解更多,请看wiki: 大圆距离

它能用于查询我们城市中所有的新闻事件: 这条查询语句仅仅会返回在radius_ in_ metres指定的半径范围内的记录,非常简单吧!

六、提高查询速度

你可能会发现上面的查询有不小的开销。以我的经验,最好对一些字段建立索引。 (下面这条语句假定你又events表, 同时events表有字段lat和lng) CREATE INDEX ${nameofindex} on events USING gits(lltoearth(lat, lng));七、数据类型

我的应用比较简单,所以我把经纬度(lat和lng)都设成了double类型。这使得我用Node.js开发起来更加快速,而不用再去自己定制针对GIST类型的解决方案。

八、就这些!

很神奇,对么?!?我们仅仅用常用的数据类型(double)就足以去用一些GEO函数创建基于地理位置的社交app九、我使用的postgreSQL语句总结(使用实例):

推荐整理分享用PostgreSQL数据库做地理位置app应用,希望有所帮助,仅作参考,欢迎阅读内容。

用PostgreSQL数据库做地理位置app应用

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Debian中PostgreSQL数据库安装配置实例 用惯了MySQL后,想尝试使用下PostgreSQL,据说这玩意儿也很强大,我在网上搜索了下相关中文书籍,可惜相关书籍远远没有MySQL那么多,不过我在官方找到

Windows下Postgresql数据库的下载与配置方法 注意下载的是二进制版,不是带WindowsInstaller的。

PostgreSQL新手入门教程 自从MySQL被Oracle收购以后,PostgreSQL逐渐成为开源关系型数据库的首选。本文介绍PostgreSQL的安装和基本用法,供初次使用者上手。以下内容基于Debian操作

标签: 用PostgreSQL数据库做地理位置app应用

本文链接地址:https://www.jiuchutong.com/biancheng/319661.html 转载请保留说明!

上一篇:phpPgAdmin 配置文件参数说明中文版(php配置文件在哪)

下一篇:Debian中PostgreSQL数据库安装配置实例

  • 利润分配未分配利润借贷方表示什么
  • 小规模增值税免征额
  • 工程施工计入资产负债表
  • 小微企业亏损还用缴残保金吗
  • 所得税费用在利润表中应在税金及附加项目中填列
  • 期末数减期初数等于
  • 电子承兑逾期提示付款说明怎么写
  • 缴纳增值税和附加税
  • 小微企业增值税优惠政策最新2023
  • 企业投资可以税后扣除吗
  • 土建工程管理费取费基数
  • 公司向股东无息借款要交哪些税
  • 土地无形资产摊销的会计处理
  • 暂估商品年底未入库汇算清缴后处理方法
  • 你如何界定成本与费用之间区别?
  • 去年税收滞纳金是个人缴的,用做账嘛
  • 公司委托其他公司为员工代缴社保公积金
  • 农产品所得税扣除比例
  • 业务招待费在企业所得税税前扣除的标准是什么?
  • 企业的资金怎么使用
  • 企业的停车违章怎么查
  • 集体房产证如何分割
  • 城建税教育费附加和地方教育费附加
  • 最新土地增值税实施细则
  • 劳务派遣公司增值税税率
  • 没有税控盘怎么开票
  • 收到分包公司工程发票收入怎么做账
  • 如何玩faceit
  • 利润的计算公式excel
  • 报销冲销借款
  • 公司给员工发放的福利都要扣个税吗
  • 获取vue实例
  • 非货币资金包括哪些科目
  • 收回已确认的坏账准备为什么在贷方
  • php反射的原理
  • echartx轴刻度设置
  • 行政单位基建账户可以建立吗为什么
  • 气温和降水空间变化一月平均气温规律是什么原因是什么
  • phpcms默认密码
  • 收支比是收入比还是利润
  • 少收的应收款和应收账款
  • 金蝶k3现金流量表编制如何生成数据
  • 增值税一般纳税人
  • 其他权益工具投资是什么类科目
  • 应计入损益的利得有什么
  • 工资薪金所得适用的税率是
  • 无偿调入资产如何做账
  • 没有发票的运输费用怎么入账
  • 企业应收账款怎么记账
  • 租单位的房子怎么办营业执照
  • 固定资产的核算内容包括
  • 无形资产账面价值计算公式
  • 被投资单位信息是什么
  • 认证过的发票红冲了还要退回吗
  • 利息支出应计入什么科目
  • 公司员工借款后还款收据怎么填
  • 房地产企业扣除项目
  • 多付款项退回怎么做账
  • 租来设备本身原因致人损害
  • 什么是成品油发票
  • 免税发票怎么抵扣
  • 银行利息增值税发票申请单怎么填
  • 新成立公司会计要做哪些事情
  • 分批法成本核算对象
  • mysql 5.7.5 m15 winx64安装配置方法图文教程
  • win8系统中断怎么解决
  • windows 10如何使用
  • Linux httpd(apache)启动失败 解决办法
  • apache for mac
  • win7系统关闭防火墙怎么关闭
  • 怎么用root登录
  • javascript数据结构与算法 pdf
  • 噩梦像连续剧
  • NGUI之UIRoot
  • jquery iframe src
  • python读取linux文件
  • android listview数据动态加载
  • 成本费用总额在报表哪里看
  • 如何当好一名税务局长
  • 服务合同需要交个人所得税嘛
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设