SlideShare a Scribd company logo
Geo/Spatial Search with MySQL Alexander Rubin Senior Consultant, MySQL AB
Why Geo Search? ,[object Object],[object Object],[object Object],[object Object]
POI Search Example
Common Tasks ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],Latitude Longitude Hotel Name
Latitudes and Longitudes
Distance between 2 points The Haversine Formula For two points on a sphere (of radius R) with latitudes φ1 and φ2, latitude separation Δφ = φ1 − φ2, and longitude separation Δλ the distance d between the two points:
The Haversine Formula in MySQL ,[object Object],[object Object],[object Object],[object Object],angles need to be in radians
MySQL Query: Find Nearby Hotels ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],Lat can be negative!
Find Nearby Hotels: Results ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
MySQL Explain query ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
How to speed up the query ,[object Object],[object Object],10 Miles
How to calculate needed coordinates ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Modify the query ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Stored procedure ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Stored Procedure, Contd ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Speed comparison ,[object Object],[object Object],[object Object],[object Object],[object Object]
Stored Procedure: Explain Plan ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Geo Search with Sphinx ,[object Object],[object Object],[object Object],[object Object]
Speed comparison of all solutions
Different Type of Coordinates ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Converting between coordinates ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Geo Search with Full Text search ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Geo Search with Full Text search: example ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Geo Search with Full Text search: Explain ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
DEMO ,[object Object],[object Object],[object Object],[object Object]
Using MySQL Spatial Extension ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Zipcode with Spatial Extension ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Spatial Search: Distance ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]
Spatial Search Example ,[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]

More Related Content

What's hot

Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019
Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019
Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019
Shota Tsuge
 

What's hot (20)

Apache Kafkaによるログ転送とパフォーマンスチューニング - Bonfire Backend #2 -
Apache Kafkaによるログ転送とパフォーマンスチューニング - Bonfire Backend #2 -Apache Kafkaによるログ転送とパフォーマンスチューニング - Bonfire Backend #2 -
Apache Kafkaによるログ転送とパフォーマンスチューニング - Bonfire Backend #2 -
 
Observability
ObservabilityObservability
Observability
 
cultura do arroz slide simplificado
cultura do arroz slide simplificadocultura do arroz slide simplificado
cultura do arroz slide simplificado
 
Adubação Alternativa e Plantas de Cobertura
Adubação Alternativa e Plantas de CoberturaAdubação Alternativa e Plantas de Cobertura
Adubação Alternativa e Plantas de Cobertura
 
k8s初心者が gRPC × envoyを導入したら色々苦労した話 #yjbonfire
k8s初心者が gRPC × envoyを導入したら色々苦労した話 #yjbonfirek8s初心者が gRPC × envoyを導入したら色々苦労した話 #yjbonfire
k8s初心者が gRPC × envoyを導入したら色々苦労した話 #yjbonfire
 
Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019
Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019
Well-Architectedな組織を
実現するためのチャレンジ - なぜ、CA W-Aを作ろうと思ったのか - #jawsdays 2019
 
Elixirと他言語の比較的紹介 ver.2
Elixirと他言語の比較的紹介ver.2Elixirと他言語の比較的紹介ver.2
Elixirと他言語の比較的紹介 ver.2
 
Assistência Técnica e Extensâo no Brasil
Assistência Técnica e Extensâo no BrasilAssistência Técnica e Extensâo no Brasil
Assistência Técnica e Extensâo no Brasil
 
JDK付属ツールにパッチを出しまくったワケ
JDK付属ツールにパッチを出しまくったワケJDK付属ツールにパッチを出しまくったワケ
JDK付属ツールにパッチを出しまくったワケ
 
Shift left Observability
Shift left ObservabilityShift left Observability
Shift left Observability
 
Colheita e Comercialização de Sorgo e Milheto
Colheita e Comercialização de Sorgo e MilhetoColheita e Comercialização de Sorgo e Milheto
Colheita e Comercialização de Sorgo e Milheto
 
エンジニア必見!Sreへの第一歩
エンジニア必見!Sreへの第一歩エンジニア必見!Sreへの第一歩
エンジニア必見!Sreへの第一歩
 
人気番組との戦い! Javaシステムのパフォーマンスチューニング奮闘記
人気番組との戦い! Javaシステムのパフォーマンスチューニング奮闘記人気番組との戦い! Javaシステムのパフォーマンスチューニング奮闘記
人気番組との戦い! Javaシステムのパフォーマンスチューニング奮闘記
 
Spring 歴約1年初心者の Test 奮闘記
Spring 歴約1年初心者の Test 奮闘記Spring 歴約1年初心者の Test 奮闘記
Spring 歴約1年初心者の Test 奮闘記
 
OAuthのHolder of Key Token
OAuthのHolder of Key TokenOAuthのHolder of Key Token
OAuthのHolder of Key Token
 
2018/1/30 Django勉強会
2018/1/30 Django勉強会2018/1/30 Django勉強会
2018/1/30 Django勉強会
 
Development myshoes and Provide Cycloud-hosted runner -- GitHub Actions with ...
Development myshoes and Provide Cycloud-hosted runner -- GitHub Actions with ...Development myshoes and Provide Cycloud-hosted runner -- GitHub Actions with ...
Development myshoes and Provide Cycloud-hosted runner -- GitHub Actions with ...
 
Milho - Segunda Safra e Escolha do Híbrido
Milho - Segunda Safra e Escolha do HíbridoMilho - Segunda Safra e Escolha do Híbrido
Milho - Segunda Safra e Escolha do Híbrido
 
Mandioca no RS.
Mandioca no RS.Mandioca no RS.
Mandioca no RS.
 
Laravel の paginate は一体何をやっているのか
Laravel の paginate は一体何をやっているのかLaravel の paginate は一体何をやっているのか
Laravel の paginate は一体何をやっているのか
 

Viewers also liked (6)

Twitter graphics and installation tutorial
Twitter graphics and installation tutorialTwitter graphics and installation tutorial
Twitter graphics and installation tutorial
 
CV (BĐS)
CV (BĐS)CV (BĐS)
CV (BĐS)
 
Creating an Interest List on Facebook
Creating an Interest List on FacebookCreating an Interest List on Facebook
Creating an Interest List on Facebook
 
Online writing for QC campus journalists
Online writing for QC campus journalistsOnline writing for QC campus journalists
Online writing for QC campus journalists
 
Online writing for campus journalists of QC
Online writing for campus journalists of QCOnline writing for campus journalists of QC
Online writing for campus journalists of QC
 
Operation report
Operation reportOperation report
Operation report
 

Similar to Geo distance search with my sql presentation

Geolocation on Rails
Geolocation on RailsGeolocation on Rails
Geolocation on Rails
nebirhos
 
OSCON july 2011
OSCON july 2011OSCON july 2011
OSCON july 2011
chelm
 
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docx
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docxCalculate_distance_and_bearing_between Latitude_Longitude_Points.docx
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docx
ssuserd02b23
 

Similar to Geo distance search with my sql presentation (20)

Geolocation
GeolocationGeolocation
Geolocation
 
Where in the world
Where in the worldWhere in the world
Where in the world
 
Geolocation on Rails
Geolocation on RailsGeolocation on Rails
Geolocation on Rails
 
10. R getting spatial
10.  R getting spatial10.  R getting spatial
10. R getting spatial
 
R getting spatial
R getting spatialR getting spatial
R getting spatial
 
Geopy module in python
Geopy module in pythonGeopy module in python
Geopy module in python
 
10. Getting Spatial
10. Getting Spatial10. Getting Spatial
10. Getting Spatial
 
Code
CodeCode
Code
 
Npc14
Npc14Npc14
Npc14
 
OSCON july 2011
OSCON july 2011OSCON july 2011
OSCON july 2011
 
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docx
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docxCalculate_distance_and_bearing_between Latitude_Longitude_Points.docx
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docx
 
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docx
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docxCalculate_distance_and_bearing_between Latitude_Longitude_Points.docx
Calculate_distance_and_bearing_between Latitude_Longitude_Points.docx
 
Stratio's Cassandra Lucene index: Geospatial use cases by Andrés Peña
Stratio's Cassandra Lucene index: Geospatial use cases by Andrés PeñaStratio's Cassandra Lucene index: Geospatial use cases by Andrés Peña
Stratio's Cassandra Lucene index: Geospatial use cases by Andrés Peña
 
Jan 2012 HUG: RHadoop
Jan 2012 HUG: RHadoopJan 2012 HUG: RHadoop
Jan 2012 HUG: RHadoop
 
Day 6 - PostGIS
Day 6 - PostGISDay 6 - PostGIS
Day 6 - PostGIS
 
Das Web Wird Mobil - Geolocation und Location Based Services
Das Web Wird Mobil - Geolocation und Location Based ServicesDas Web Wird Mobil - Geolocation und Location Based Services
Das Web Wird Mobil - Geolocation und Location Based Services
 
Geo search introduction
Geo search introductionGeo search introduction
Geo search introduction
 
Stratio's Cassandra Lucene index: Geospatial use cases
Stratio's Cassandra Lucene index: Geospatial use casesStratio's Cassandra Lucene index: Geospatial use cases
Stratio's Cassandra Lucene index: Geospatial use cases
 
Stratio's Cassandra Lucene index: Geospatial Use Cases (Andrés de la Peña & J...
Stratio's Cassandra Lucene index: Geospatial Use Cases (Andrés de la Peña & J...Stratio's Cassandra Lucene index: Geospatial Use Cases (Andrés de la Peña & J...
Stratio's Cassandra Lucene index: Geospatial Use Cases (Andrés de la Peña & J...
 
Udp socket programming(Florian)
Udp socket programming(Florian)Udp socket programming(Florian)
Udp socket programming(Florian)
 

Geo distance search with my sql presentation

Editor's Notes

  1. ADD EXPLAIN PLAN
  2. ADD EXPLAIN PLAN