cratedb支持的geo 查询还相对比较全,开发基本的功能已经够用了

安装cratedb

使用docker

docker run -d -p 4200:4200 crate

创建数据库

  • 创建表
CREATE TABLE country (
name string,
country_code string primary key,
shape geo_shape INDEX USING "geohash" WITH (precision='100m'),
capital string,
capital_location geo_point
) WITH (number_of_replicas=0);
  • 添加数据
INSERT INTO country (mame, country_code, shape, capital, capital_location)
VALUES (
'Austria',
'at',
{type='Polygon', coordinates=[
[[16.979667, 48.123497], [16.903754, 47.714866],
[16.340584, 47.712902], [16.534268, 47.496171],
[16.202298, 46.852386], [16.011664, 46.683611],
[15.137092, 46.658703], [14.632472, 46.431817],
[13.806475, 46.509306], [12.376485, 46.767559],
[12.153088, 47.115393], [11.164828, 46.941579],
[11.048556, 46.751359], [10.442701, 46.893546],
[9.932448, 46.920728], [9.47997, 47.10281],
[9.632932, 47.347601], [9.594226, 47.525058],
[9.896068, 47.580197], [10.402084, 47.302488],
[10.544504, 47.566399], [11.426414, 47.523766],
[12.141357, 47.703083], [12.62076, 47.672388],
[12.932627, 47.467646], [13.025851, 47.637584],
[12.884103, 48.289146], [13.243357, 48.416115],
[13.595946, 48.877172], [14.338898, 48.555305],
[14.901447, 48.964402], [15.253416, 49.039074],
[16.029647, 48.733899], [16.499283, 48.785808],
[16.960288, 48.596982], [16.879983, 48.470013],
[16.979667, 48.123497]]
]},
'Vienna',
[16.372778, 48.209206]
);

数据查询

具体语法可以参考参考资料对应的连接

  • 支持match
SELECT name from country
WHERE match("shape",
'LINESTRING (13.3813 52.5229, 11.1840 51.5497, 8.6132 50.0782, 8.3715 47.9457, 8.5034 47.3685)'
);
  • intersects distance within
SELECT within(capital_location, shape) AS capital_in_country
FROM country; SELECT distance(capital_location, 'POINT(0.0 90.0)') as from_northpole
FROM country ORDER BY country_code; SELECT intersects(
{type='LineString', coordinates=[[13.3813, 52.5229],
[11.1840, 51.5497],
[8.6132, 50.0782],
[8.3715, 47.9457],
[8.5034, 47.3685]]},
shape) as berlin_zurich_intersects
FROM country ORDER BY country_code;

参考资料

https://crate.io/docs/crate/reference/en/latest/general/dql/geo.html

 
 
 
 

cratedb geo 查询的更多相关文章

  1. 基于百度地图SDK和Elasticsearch GEO查询的地理围栏分析系统(1)

    本文描述了一个系统,功能是评价和抽象地理围栏(Geo-fencing),以及监控和分析核心地理围栏中业务的表现. 技术栈:Spring-JQuery-百度地图WEB SDK 存储:Hive-Elast ...

  2. 基于百度地图SDK和Elasticsearch GEO查询的地理围栏分析系统(2)-查询实现

    在上一篇博客中,我们准备好了数据.现在数据已经以我们需要的格式,存放在Elasticsearch中了. 本文讲述如何在Elasticsearch中进行空间GEO查询和聚合查询,以及如何准备ajax接口 ...

  3. 015-elasticsearch5.4.3【五】-搜索API【四】Joining 多文档查询、GEO查询、moreLikeThisQuery、script脚本查询、span跨度查询

    一.Joining 多文档查询 joining query 像Elasticsearch这样的分布式系统中执行完整的SQL样式连接非常昂贵.相反,Elasticsearch提供两种形式的连接,旨在水平 ...

  4. 基于百度地图SDK和Elasticsearch GEO查询的地理围栏分析系统(3)-前端实现

    转载自:http://www.cnblogs.com/Auyuer/p/8086975.html MoonLight可视化订单需求区域分析系统实现功能: 在现实生活中,计算机和互联网迅速发展,人们越来 ...

  5. Elasticsearch java API (23)查询 DSL Geo查询

    地理查询编辑 Elasticsearch支持两种类型的地理数据: geo_point纬度/经度对字段的支持,和 geo_shape领域,支持点.线.圆.多边形.多等. 这组查询: geo_shape  ...

  6. Elasticsearch(GEO)空间检索查询

    Elasticsearch(GEO)空间检索查询python版本 1.Elasticsearch ES的强大就不用多说了,当你安装上插件,搭建好集群,你就拥有了一个搜索系统. 当然,ES的集群优化和查 ...

  7. mongoTemplate CURD 和模糊查询(转)

    此文基于Spring的MongoTemplate,介绍MongoDB比较基础常用的增删改查操作.涵盖了从集合创建.索引创建和CRUD操作到更高级的功能(如Map-Reduce和聚合)等等.不多说,直接 ...

  8. TableStore最佳实践:GEO索引打造店铺搜索系统

    摘要: 如何使用TableStore打造店铺搜索系统 一.方案背景 对于一套GEO管理系统,其核心点与瓶颈在于数据库的存储性能与查询能力:一方面,存储服务需要应对海量数据的低延迟存.读,另一方面,存储 ...

  9. ES7学习笔记(十三)GEO位置搜索

    ES的基本内容介绍的已经差不多了,最后我们再来看看GEO位置搜索,现在大部分APP都有基于位置搜索的功能,比如:我们点外卖,可以按照离我们的距离进行排序,这样可以节省我们的配送费和送餐的时间:还有找工 ...

随机推荐

  1. 2018 Multi-University Training Contest 9 Solution

    A - Rikka with Nash Equilibrium 题意:构造一个$n * m$的矩阵,使得$[1, n * m]$ 中每个数只出现一次,并且纳什均衡只出现一次. 思路:从大到小的放置,每 ...

  2. 2017 ACM/ICPC Asia Regional Qingdao Online Solution

    A : Apple 题意:给出三个点,以及另一个点,求最后一个点是否在三个点的外接圆里面,如果在或者在边界上,输出“Rejected”,否则输出"Accepted" 思路:先求一个 ...

  3. Android 多媒体MediaPlayer使用详解

    现在的手机功能越来越丰富了,遥想10年前,MP3,MP4,MP5,还是很流行的,博主当时读高中时很想拥有一台,可以听音乐和看电影.可是条件有限,学校也禁止此东西,所以只能偷偷的玩.而现在我们的手机也很 ...

  4. zabbix监控路由器

    在路由器上添加团体名: snmp-server enable traps snmp-server community XXXX rw   1.使用Getif查看路由器端口信息 getif-2.31

  5. 20145204 《Java程序设计》第7周学习总结

    20145204 <Java程序设计>第7周学习总结 教材学习内容总结 时间 GMT.UT.TAI 格林威治标准时间(GMT)的正午是太阳抵达天空最高点之时,因为地球公转轨道为椭圆且速度不 ...

  6. 20145311 《Java程序设计》第七周学习总结

    20145311 <Java程序设计>第七周学习总结 教材学习内容总结 第十二章 Lambda Lambda表达式会使程序更加地简洁,在平行设计的时候,能够进行并行处理. 第十三章 时间与 ...

  7. linux下如何关闭某个tmux窗口

    答:分成两个步骤,如下: 1.列出当前的tmux窗口 jello@jello:~$ tmux ls 1: 1 windows (created Tue Jan 17 09:28:05 2019) [2 ...

  8. System.data.sqlite安装

    在这个页面可以下载安装不同版本的 http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki x86的版本可以在64位机 ...

  9. Solidity 官方文档中文版 4_Solidity 编程实例

    Voting 投票 接下来的合约非常复杂,但展示了很多Solidity的特性.它实现了一个投票合约.当然,电子选举的主要问题是如何赋予投票权给准确的人,并防止操纵.我们不能解决所有的问题,但至少我们会 ...

  10. R中的路径设置

    软件的路径设置对于电脑的内存管理和自己的寻根究底十分重要.所以,合理的设置R中相关路径,能更加方便快捷的管理自己的相关文件,提高学习R语言的效率,建立自己的习惯体系. R中的路径设置主要有以下几个方面 ...