指定一个经纬度,给定一个范围值(单位:千米),查出在经纬度周围这个范围内的数据。
经度:113.914619
纬度:22.50128
范围:2km
longitude为数据表经度字段
latitude为数据表纬度字段
SQL在mysql下测试通过,其他数据库可能需要修改
SQL语句如下:
select * from location where sqrt( ( ((113.914619-longitude)*PI()12656cos(((22.50128+latitude)/2)*PI()/180)/180) * ((113.914619-longitude)*PI()12656cos (((22.50128+latitude)/2)*PI()/180)/180) ) + ( ((22.50128-latitude)*PI()*12656/180) * ((22.50128-latitude)*PI()*12656/180) ) )<2

MySQL性能调优 – 使用更为快速的算法进行距离
最近遇到了一个问题,通过不断的尝试最终将某句原本占据近1秒的查询优化到了0.01秒,效率提高了100倍.

问题是这样的,有一张存放用户居住地点经纬度信息的MySQL数据表,表结构可以简化 为:id(int),longitude(long),latitude()long. 而业务系统中有一个功能是查找离某个用户最近的其余数个用户,通过代码分析,可以确定原先的做法基本是这样的:

//需要查询的用户的坐标

$lat=20; $lon=20;//执行查询,算出该用户与所有其他用户的距离,取出最近的10个 sql=′select∗fromuserslocationorderbyACOS(SIN((′.sql='select * from users_location order by ACOS(SIN(('.sql=′select∗fromusersl​ocationorderbyACOS(SIN((′.lat.’ * 3.1415) / 180 ) *SIN((latitude * 3.1415) / 180 ) +COS((’.lat.′∗3.1415)/180)∗COS((latitude∗3.1415)/180)∗COS((′.lat.' * 3.1415) / 180 ) * COS((latitude * 3.1415) / 180 ) *COS(('.lat.′∗3.1415)/180)∗COS((latitude∗3.1415)/180)∗COS((′.lon.’ * 3.1415) / 180 - (longitude * 3.1415) / 180 ) ) * 6380 asc limit 10’;
而这条sql执行的速度却非常缓慢,用了近1秒的时间才返回结果,应该是因为order里的子语句用了太多的数学计算公式,导致整体的运算速度下降.

而在实际的使用中,不太可能会发生需要计算该用户与所有其他用户的距离,然后再排序的情况,当用户数量达到一个级别时,就可以在一个较小的范围里进行搜索,而非在所有用户中进行搜索.

所以对于这个例子,我增加了4个where条件,只对于经度和纬度大于或小于该用户1度(111公里)范围内的用户进行距离计算,同时对数据表中的经度和纬度两个列增加了索引来优化where语句执行时的速度.

最终的sql语句如下

sql=′select∗fromuserslocationwherelatitude>′.sql='select * from users_location where latitude > '.sql=′select∗fromusersl​ocationwherelatitude>′.lat.’-1 and latitude < ‘.lat.′+1andlongitude>′.lat.'+1 and longitude > '.lat.′+1andlongitude>′.lon.’-1 and longitude < ‘.lon.′+1orderbyACOS(SIN((′.lon.'+1 order by ACOS(SIN(('.lon.′+1orderbyACOS(SIN((′.lat.’ * 3.1415) / 180 ) SIN((latitude * 3.1415) / 180 ) +COS((’.lat.′∗3.1415)/180)∗COS((latitude∗3.1415)/180)∗COS((′.lat.' * 3.1415) / 180 ) * COS((latitude * 3.1415) / 180 ) *COS(('.lat.′∗3.1415)/180)∗COS((latitude∗3.1415)/180)∗COS((′.lon.’ 3.1415) / 180 - (longitude * 3.1415) / 180 ) ) * 6380 asc limit 10’;

sql语句查询经纬度范围相关推荐

  1. sql语句查询经纬度范围 Oracle

    指定一个经纬度,给定一个范围值(单位:千米),查出在经纬度周围这个范围内的数据.  经度:23.33  纬度:34.66  范围:2000km  SA_LONGITUDE为数据表经度字段  SA_LA ...

  2. Oracle经纬度查询最近sql,SQL语句计算经纬度距离

    二: SQL语句计算经纬度距离 SELECT id, ( 6371* acos( cos( radians(37) ) * cos( radians( lat ) ) * cos( radians( ...

  3. Sql语句查询 显示序号

    怎么样用SQL语句查询出来带有序号,不是我们用递增所带的ID号 就是按行数用数字显示出来 序号,id,userid 1 5 aaa 2 6 bbb 3 8 ccc 4 9 ddd 5 17 eee 类 ...

  4. sql语句查询过慢的原因分析

    有时候你在使用sql语句查询数据库,sql语句写得好正确,但则发现执行查询的时候很慢呢?数据量也不是太大,你知道其中的原因吗?本文给大家讲解一下sql查询过慢的48种原因分析,请阅读. 1.没有索引或 ...

  5. thinkphp5基本的一些操作/API友好/获取请求信息(Request)/判断请求类型(GET...)/验证参数数据(Validate)/连接数据库/原生sql语句查询

    文章目录 一.API友好 1.举两个thinkphp5关于API友好的例子 (1)数据输出 (2)错误调试Trace 二.获取请求信息(Request) 1.获取URL信息 2.获取 模块/控制器/操 ...

  6. 一条SQL语句查询数据库中的所有表、存储过程、触发器

    一条SQL语句查询数据库中的所有表.存储过程.触发器 (sysobjects表信息)   该条语句查询返回所有的用户表 select * from sysobjects where xtype='u' ...

  7. 案例:用一条 SQL 语句查询出每门课都大于 80 分的学生姓名

    用一条sql语句查询出每门课都大于80分的学生姓名 首先需要进行分析: 要查询出每门课程都大于80分的学生姓名,因为一个学生有多门课程,所以会出现下面三种情况. 第一可能所有课程都大于80分. 第二可 ...

  8. 如何用SQL语句查询Excel数据

    Q:如何用SQL语句查询Excel数据? A:下列语句可在SQL SERVER中查询Excel工作表中的数据. 2007和2010版本: SELECT *  FROM OpenDataSource(  ...

  9. oracle图书操作、sql语句查询+授权、视图、索引、表操作

    oracle图书操作.sql语句查询+授权.视图.索引.表操作 一.创建一张表book,表结构为(总编号,分类号,书名,作者,出版单位,单价),插入若干记录 二.创建一张表reader,表结构为(借书 ...

最新文章

  1. Missing space before value for key ‘routes‘ key-spacing
  2. sqlserver怎么查看索引_Sql Server之旅——第六站 为什么都说状态少的字段不能建索引...
  3. 查看tensorflow pb模型文件的节点信息
  4. busybox 安装mysql_安装busybox
  5. base64 RFC 4648
  6. 抽象工厂产品等级结构与产品族
  7. Matlab--max,min函数的用法
  8. oracle数据库将一列的值拼接成一行,并且各个值之间用逗号隔开
  9. 数据科学 IPython 笔记本 8.12 文本和注解
  10. Educational Codeforces Round 68 (Rated for Div. 2)-D. 1-2-K Game
  11. 启发式算法之遗传算法--求解组合优化问题
  12. DIY智能车赛优胜奖开源作品——手机遥控麦克纳姆轮小车(1)
  13. 行业标准 | 证券期货经营机构信息系统备份能力标准 JR/T 0059—2010
  14. Bn层之前的卷积层不需要加偏执
  15. QQ邮箱搜索器 邮箱地址批量搜索
  16. C++ 利用管道操作本机命令行命令
  17. mysql时间戳转换大日期 2038 以上 2099
  18. 对摄影术语(及其在光线追踪的应用)的简要概括
  19. 钱多多的编程语言晋升路
  20. 操作系统原理,交互式系统常见的调度算法,时间片轮转RR,虚拟轮转VRR,最高优先级调度,优先级反转问题与应对

热门文章

  1. Linux 设置Docker容器开机自启动,Dokcer容器常用命令总结。
  2. Django运行项目卡住了没有反应Watching for file changes with StatReloader Performing system checks... System che
  3. 射频通信半导体硅基氮化镓(GaN-on-Si)技术解析
  4. 前端代码优化(持续更新中)
  5. 海店湾密探:直播行业退潮,致使写字楼空置率全面飙升!
  6. 尝试用Verilog驱动VGA
  7. Android App开发之自定义图形中位图与图形互转、剪裁图形内部区域、给图形添加部件的讲解及实战(附源码 简单易懂)
  8. linux 超级平板电脑,Archos 5:人人都可拥有的Linux平板电脑
  9. CMOS传感器的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告
  10. java之TreeNode