1、solr版本

solr7+

2、solr 经纬度查询的方式

  1. 使用LatLonType(用于平面坐标,而不是大地坐标)
  2. SpatialRecursivePrefixTreeFieldType(缩写为RPT)
  3. 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 实现对经纬度的查询相关推荐

  1. solr经纬度坐标查询

    最近项目中使用到了solr,并且需求中需要通过给定一个经纬度,查询附件方圆多少多少范围的店铺信息,网上查了一下资料,大致总结了一下有几种使用方式 1.使用LatLonType(用于平面坐标,而不是大地 ...

  2. 基于Solr的HBase多条件查询测试

    背景: 某电信项目中采用HBase来存储用户终端明细数据,供前台页面即时查询.HBase无可置疑拥有其优势,但其本身只对rowkey支持毫秒级的快速检索,对于多字段的组合查询却无能为力.针对HBase ...

  3. solr的多条件组合查询和solr的范围查询【转】

    solr的多条件组合查询和solr的范围查询 版权声明:本文为博主原创文章,供大家参考,但不要抄袭哦! 存在问题:为了减轻数据库的访问压力,往往我们将必要的数据存储到solr中,并给部分字段建立索引, ...

  4. 微信如何根据经纬度坐标查询具体地理位置

    微信如何根据经纬度坐标查询具体地理位置 好多人会问为什么微信高级接口获取的坐标信息位置不准,主要原因不是微信获取的不准,而是微信获取的是gps坐标,如果你直接用百度或google的api去解析的话肯定 ...

  5. thinkphp5范围查询_ThinkPHP实现经纬度范围查询

    ThinkPHP实现经纬度范围查询 JamesLiu • 2019 年 05 月 13 日 经纬度范围获取 /** * Desc: 根据经纬度,半径范围获取附近 * User: JamesLiu * ...

  6. solr的多条件组合查询

    今天,再工作中遇到了solr的多条件组合查询,于是在网上查到一些博客--多条件查询,这篇写的不错,但是我也想把我自己的记录下来.话不多说,直接放代码.注意:,在接收的参数由于都是String类型的,所 ...

  7. solr 英文模拟mysql like查询xml_Solr之精确、匹配、排序、模糊查询-yellowcong

    Solr查询数据,其实下面一堆的参数,我也没有做测试,只是转载过来了,我大概只用了高亮.排序.查询.分页,其他的好像没有用过,以后用再来查 一.基本查询 参数意义 q 查询的关键字,此参数最为重要,例 ...

  8. solr 英文模拟mysql like查询xml_Solr实现类似MySQL的LIKE查询功能

    最近在工作中遇到需要对大文本进行关键词查询.需要实现的效果为,当用户输入一个字或者一个词,要搜出包含这个字或者词的所有内容.就相当于MySQL的LIKE查询效果一样. 在这种场景下,第一时间想到的肯定 ...

  9. 经纬度在线查询,地名(批量)查询经纬度,经纬度(批量)查询地名

    http://map.yanue.net/geo.html 这是运用google map api v3开发的地图应用,使用谷歌地图地址解析服务,主要实现经纬度和地名之间相互解析功能,同时实现了批量解析 ...

最新文章

  1. 如何使用JPA注解标注多对多的关系
  2. 雷林鹏分享:jQuery EasyUI 数据网格 - 创建属性网格
  3. 数据结构 树的链式存储(二叉表示法)
  4. 翻译关于ViewController的一篇文章
  5. fastjson反序列化漏洞_漏洞预警Fastjson再爆反序列化代码执行漏洞;星巴克被发现存在信息泄露风险...
  6. vb红绿灯自动切换_什么是自动驻车
  7. python刷题总结_【python刷题】差分数组
  8. HDU 4920 Matrix multiplication(矩阵相乘)
  9. 的driver_Spark源码解析(三)----Driver启动、注册Application
  10. 项目 协程-实现非抢占式TCP服务器
  11. c语言程序设计逗号作用,逗号运算符C语言程序设计.pdf
  12. nginx封锁恶意IP,并且定时取消的两种脚本
  13. 软件系统的测试计划,软件系统测试计划-模板
  14. wxpython控件字体_wxPython获取系统字体代码
  15. RocksDB Compaction(一)介绍
  16. LaTeX 公式(转自)Iowa_Battleship 神犇
  17. Android Bmob后端云—数据库、服务器!
  18. 第10章:项目沟通管理和干系人管理-章节真题
  19. 华为云照片的爬虫程序更新(python3.6)
  20. 1093:计算多项式的值

热门文章

  1. C语言网络编程:TCP客户端实现
  2. XPath与多线程爬虫
  3. RenderTree渲染树
  4. LeetCode 7. Reverse Integer
  5. Intellij IDEA的下载和使用(针对学生的免费使用计划)
  6. 012-python基础-数据运算
  7. cocoapods更新
  8. Android静态变量的生命周期
  9. 日期NSDate的使用
  10. 解决firefox ubuntu无法打开页面的问题