solr 实现对经纬度的查询
1、solr版本
solr7+
2、solr 经纬度查询的方式
- 使用LatLonType(用于平面坐标,而不是大地坐标)
- SpatialRecursivePrefixTreeFieldType(缩写为RPT)
- BBoxField(用于边界索引查询)
2.1 使用 LatLonPointSpatialField
创建一个索引库,名叫newCore
在 conf 文件夹中找到 managed-schema 文件, 新增 以下域字段
<field name="loc" type="location" indexed="true" stored="true" required="true" multiValued="false" />
<field name="id" type="string" indexed="true" stored="true" required="false" multiValued="false" />
测试代码 新增坐标 到solr服务器中
@Autowiredprivate SolrClient solrClient;@Testpublic void addDoc11() throws SolrServerException, IOException {Random r = new Random();// 随机数Collection<SolrInputDocument> docList = new ArrayList<SolrInputDocument>();for (int i = 0; i < 10000; i++) {SolrInputDocument document = new SolrInputDocument();String id = i + "_solr";// 纬度范围是-90~90,经度范围-180~180String loc = (r.nextInt(180) - 90) + "," + (r.nextInt(360) - 180);document.addField("id", id);document.addField("loc", loc);docList.add(document);}solrClient.add(docList);solrClient.commit();}
生成以下数据
使用浏览器进行访问
#距离经纬度 45,94 1000km 所有的经纬度 降序排列
http://localhost:8983/solr/newcore/select?q=*:*&fq={!geofilt}&sfield=loc&pt=45,94&d=1000&start=0&rows=10&sort=geodist()%20asc
注意的是,此数据个是 (经度,纬度) 例如 (33,72)
参考资料 1:https://www.cnblogs.com/tony-zt/p/9260017.html solr7 的安装与使用
参考资料2 :https://blog.csdn.net/dmw412724/article/details/86520569 使用以上方式 进行sorl 的经纬查询
2、使用SpatialRecursivePrefixTreeFieldType
在 conf 文件夹中找到 managed-schema 文件, 新增 以下域字段
<field name="id" type="string" indexed="true" stored="true" required="true" multiValued="false" /><field name="station_address" type="text_general" indexed="true" stored="true"/><field name="station_position" type="location_rpt" indexed="true" stored="true"/>
location_rpt 的数据类型是
<fieldType name="location_rpt" class="solr.SpatialRecursivePrefixTreeFieldType"geo="true" distErrPct="0.025" maxDistErr="0.000009" distanceUnits="kilometers" />
测试代码
@Autowiredprivate SolrClient solrClient;@Testpublic void addDocRpt() throws SolrServerException, IOException {SolrInputDocument doc = new SolrInputDocument(); doc.addField("id","1"); doc.addField("station_address", "北京");String posString = "112.0541"+" "+"30.96029";doc.addField("station_position", posString);solrClient.add(doc);solrClient.commit();}
此数据入索引库的格式 是 (122.0122‘需要一个空格’30.9994) (112.0033 34.0008)
使用浏览器进行访问
# 查询与 112.0423 30.97878 经纬度距离 3km 范围的所有点
http://localhost:8983/solr/newcore/select?q=*:*&fq={!geofilt}&sfield=station_position&pt=112.0423%2030.97878&d=3&start=0&rows=10&sort=geodist()%20asc
查询结果
参考资料1:http://www.itkeyword.com/doc/2543881900536538500/apache%20latLon-solr 设置排序
参考资料2:https://blog.csdn.net/larger5/article/details/79768438 solr的操作
参考资料3:http://www.yanglajiao.com/article/u010346953/69934323 solr的操作
参考资料4:https://blog.csdn.net/u014508939/article/details/85165807 使用 SpatialRecursivePrefixTreeFieldType
参考资料5:http://www.hhlink.com/%E7%BB%8F%E7%BA%AC%E5%BA%A6/ 经纬度计算
pom文件
<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-solr</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies>
solr 实现对经纬度的查询相关推荐
- solr经纬度坐标查询
最近项目中使用到了solr,并且需求中需要通过给定一个经纬度,查询附件方圆多少多少范围的店铺信息,网上查了一下资料,大致总结了一下有几种使用方式 1.使用LatLonType(用于平面坐标,而不是大地 ...
- 基于Solr的HBase多条件查询测试
背景: 某电信项目中采用HBase来存储用户终端明细数据,供前台页面即时查询.HBase无可置疑拥有其优势,但其本身只对rowkey支持毫秒级的快速检索,对于多字段的组合查询却无能为力.针对HBase ...
- solr的多条件组合查询和solr的范围查询【转】
solr的多条件组合查询和solr的范围查询 版权声明:本文为博主原创文章,供大家参考,但不要抄袭哦! 存在问题:为了减轻数据库的访问压力,往往我们将必要的数据存储到solr中,并给部分字段建立索引, ...
- 微信如何根据经纬度坐标查询具体地理位置
微信如何根据经纬度坐标查询具体地理位置 好多人会问为什么微信高级接口获取的坐标信息位置不准,主要原因不是微信获取的不准,而是微信获取的是gps坐标,如果你直接用百度或google的api去解析的话肯定 ...
- thinkphp5范围查询_ThinkPHP实现经纬度范围查询
ThinkPHP实现经纬度范围查询 JamesLiu • 2019 年 05 月 13 日 经纬度范围获取 /** * Desc: 根据经纬度,半径范围获取附近 * User: JamesLiu * ...
- solr的多条件组合查询
今天,再工作中遇到了solr的多条件组合查询,于是在网上查到一些博客--多条件查询,这篇写的不错,但是我也想把我自己的记录下来.话不多说,直接放代码.注意:,在接收的参数由于都是String类型的,所 ...
- solr 英文模拟mysql like查询xml_Solr之精确、匹配、排序、模糊查询-yellowcong
Solr查询数据,其实下面一堆的参数,我也没有做测试,只是转载过来了,我大概只用了高亮.排序.查询.分页,其他的好像没有用过,以后用再来查 一.基本查询 参数意义 q 查询的关键字,此参数最为重要,例 ...
- solr 英文模拟mysql like查询xml_Solr实现类似MySQL的LIKE查询功能
最近在工作中遇到需要对大文本进行关键词查询.需要实现的效果为,当用户输入一个字或者一个词,要搜出包含这个字或者词的所有内容.就相当于MySQL的LIKE查询效果一样. 在这种场景下,第一时间想到的肯定 ...
- 经纬度在线查询,地名(批量)查询经纬度,经纬度(批量)查询地名
http://map.yanue.net/geo.html 这是运用google map api v3开发的地图应用,使用谷歌地图地址解析服务,主要实现经纬度和地名之间相互解析功能,同时实现了批量解析 ...
最新文章
- 如何使用JPA注解标注多对多的关系
- 雷林鹏分享:jQuery EasyUI 数据网格 - 创建属性网格
- 数据结构 树的链式存储(二叉表示法)
- 翻译关于ViewController的一篇文章
- fastjson反序列化漏洞_漏洞预警Fastjson再爆反序列化代码执行漏洞;星巴克被发现存在信息泄露风险...
- vb红绿灯自动切换_什么是自动驻车
- python刷题总结_【python刷题】差分数组
- HDU 4920 Matrix multiplication(矩阵相乘)
- 的driver_Spark源码解析(三)----Driver启动、注册Application
- 项目 协程-实现非抢占式TCP服务器
- c语言程序设计逗号作用,逗号运算符C语言程序设计.pdf
- nginx封锁恶意IP,并且定时取消的两种脚本
- 软件系统的测试计划,软件系统测试计划-模板
- wxpython控件字体_wxPython获取系统字体代码
- RocksDB Compaction(一)介绍
- LaTeX 公式(转自)Iowa_Battleship 神犇
- Android Bmob后端云—数据库、服务器!
- 第10章:项目沟通管理和干系人管理-章节真题
- 华为云照片的爬虫程序更新(python3.6)
- 1093:计算多项式的值