之前很傻很天真地以为无非就是逐个计算距离,然后比较出来就行了,然后当碰到访问用户很多,而且数据库中经纬度信息很多的时候,计算量的迅速增长,能让服务器完全傻逼掉,还是老前辈的经验比我们丰富,给了我很大的启示。

MySQL性能调优 – 使用更为快速的算法进行距离计算

最近遇到了一个问题,通过不断的尝试最终将某句原本占据近1秒的查询优化到了0.01秒,效率提高了100倍.

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

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

1 $lat=20;
2 $lon=20;//执行查询,算出该用户与所有其他用户的距离,取出最近的10个
3 $sql='select * from users_location order by ACOS(SIN(('.$lat.' * 3.1415) / 180 ) *SIN((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语句如下

1 $sql='select * from users_location where
2 latitude > '.$lat.'-1 and
3 latitude < '.$lat.'+1 and
4 longitude > '.$lon.'-1 and
5 longitude < '.$lon.'+1
6 order by ACOS(SIN(('.$lat.' 3.1415) / 180 ) *SIN((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大大提高了运行速度,在某些情况下甚至有100倍的提升.这种从业务角度出发,缩小sql查询范围的方法也可以适用在其他地方.

原文地址:  http://blog.csdn.net/hustpzb/article/details/7688993

最新文章

  1. 手把手教你编译安装MariaDB
  2. Immutable api example
  3. python处理xml文件
  4. 给Debian安装Xfce桌面
  5. JavaScript语句
  6. VS构建工具介绍
  7. operation not possible due to RF-kill
  8. ionic cordova plugin for ios
  9. String的点点滴滴
  10. Python自动化运维之10、模块之json、pickle、XML、PyYAML、configparser、shutil
  11. zabbix client安装配置执行
  12. Android 反编译(一,apktool+smail2java)
  13. 十、 Spring Boot Shiro 权限管理
  14. Python笔记(一):安装+爬虫环境配置+打包为EXE文件
  15. June 30th. 2018, Week 26th. Saturday
  16. jmeter5.1在windows(含插件安装)及linux环境下安装
  17. 【论文学习】YOLO9000: Better,Faster,Stronger(YOLO9000:更好,更快,更强)
  18. [转]ionic工作原理
  19. HTML+CSS:圆形和圆角图片格式
  20. python读取配置文件&amp;&amp;简单封装

热门文章

  1. 最简单的SVN环境搭建过程
  2. 深入理解javascript函数系列第一篇——函数概述
  3. RAC碎碎念
  4. CentOS安装运行NodeJS框架Express
  5. mac+apache+php+phpmyadmin集成php开发环境配置
  6. eclipse推荐的插件
  7. Azure ARM (11) ARM模式下,创建虚拟机并配置负载均衡器
  8. java并发编程读书笔记(1)-- 对象的共享
  9. Elasticsearch增删改查 之 —— Update更新
  10. ES6笔记(6)-- Set、Map结构和Iterator迭代器