SlideShare a Scribd company logo
1 of 29
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

15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...
15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...
15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...Μάκης Χατζόπουλος
 
OPcache の最適化器の今
OPcache の最適化器の今OPcache の最適化器の今
OPcache の最適化器の今y-uti
 
constexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだ
constexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだconstexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだ
constexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだGenya Murakami
 
Διαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπής
Διαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπήςΔιαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπής
Διαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπήςΜάκης Χατζόπουλος
 
ゲーム開発者のための C++11/C++14
ゲーム開発者のための C++11/C++14ゲーム開発者のための C++11/C++14
ゲーム開発者のための C++11/C++14Ryo Suzuki
 
NTUSTxTDOH - Pwn基礎 2015/12/27
NTUSTxTDOH - Pwn基礎 2015/12/27NTUSTxTDOH - Pwn基礎 2015/12/27
NTUSTxTDOH - Pwn基礎 2015/12/27Sheng-Hao Ma
 
WebRTC multitrack / multistream
WebRTC multitrack / multistreamWebRTC multitrack / multistream
WebRTC multitrack / multistreammganeko
 
Intel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgen
Intel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgenIntel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgen
Intel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgenMITSUNARI Shigeo
 
Qemu device prototyping
Qemu device prototypingQemu device prototyping
Qemu device prototypingYan Vugenfirer
 
犬でもわかる公開鍵暗号
犬でもわかる公開鍵暗号犬でもわかる公開鍵暗号
犬でもわかる公開鍵暗号akakou
 
LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)
LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)
LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)Takeshi Yamamuro
 
katagaitai CTF勉強会 #5 Crypto
katagaitai CTF勉強会 #5 Cryptokatagaitai CTF勉強会 #5 Crypto
katagaitai CTF勉強会 #5 Cryptotrmr
 
Pythonおじさんのweb2py挑戦記
Pythonおじさんのweb2py挑戦記Pythonおじさんのweb2py挑戦記
Pythonおじさんのweb2py挑戦記Yoshiyuki Nakamura
 
GPUが100倍速いという神話をぶち殺せたらいいな ver.2013
GPUが100倍速いという神話をぶち殺せたらいいな ver.2013GPUが100倍速いという神話をぶち殺せたらいいな ver.2013
GPUが100倍速いという神話をぶち殺せたらいいな ver.2013Ryo Sakamoto
 

What's hot (20)

ECMAScript没proposal追悼式
ECMAScript没proposal追悼式ECMAScript没proposal追悼式
ECMAScript没proposal追悼式
 
1215 SAS 實習課
1215 SAS 實習課1215 SAS 實習課
1215 SAS 實習課
 
15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...
15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...
15 θέματα από το βιβλίο 100 Θέματα Μαθηματικών του Λουκά Κανάκη - Εκδόσεις: Μ...
 
OPcache の最適化器の今
OPcache の最適化器の今OPcache の最適化器の今
OPcache の最適化器の今
 
constexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだ
constexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだconstexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだ
constexpr関数はコンパイル時処理。これはいい。実行時が霞んで見える。cpuの嬌声が聞こえてきそうだ
 
Διαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπής
Διαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπήςΔιαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπής
Διαγώνισμα στο Διαφορικό Λογισμό μέχρι σημεία καμπής
 
ゲーム開発者のための C++11/C++14
ゲーム開発者のための C++11/C++14ゲーム開発者のための C++11/C++14
ゲーム開発者のための C++11/C++14
 
NTUSTxTDOH - Pwn基礎 2015/12/27
NTUSTxTDOH - Pwn基礎 2015/12/27NTUSTxTDOH - Pwn基礎 2015/12/27
NTUSTxTDOH - Pwn基礎 2015/12/27
 
WebRTC multitrack / multistream
WebRTC multitrack / multistreamWebRTC multitrack / multistream
WebRTC multitrack / multistream
 
Virtual Machine Constructions for Dummies
Virtual Machine Constructions for DummiesVirtual Machine Constructions for Dummies
Virtual Machine Constructions for Dummies
 
Intel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgen
Intel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgenIntel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgen
Intel AVX-512/富岳SVE用SIMDコード生成ライブラリsimdgen
 
Qemu device prototyping
Qemu device prototypingQemu device prototyping
Qemu device prototyping
 
Unix v6 Internals
Unix v6 InternalsUnix v6 Internals
Unix v6 Internals
 
犬でもわかる公開鍵暗号
犬でもわかる公開鍵暗号犬でもわかる公開鍵暗号
犬でもわかる公開鍵暗号
 
LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)
LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)
LLVMで遊ぶ(整数圧縮とか、x86向けの自動ベクトル化とか)
 
Gcc porting
Gcc portingGcc porting
Gcc porting
 
katagaitai CTF勉強会 #5 Crypto
katagaitai CTF勉強会 #5 Cryptokatagaitai CTF勉強会 #5 Crypto
katagaitai CTF勉強会 #5 Crypto
 
Pythonおじさんのweb2py挑戦記
Pythonおじさんのweb2py挑戦記Pythonおじさんのweb2py挑戦記
Pythonおじさんのweb2py挑戦記
 
私とOSSの25年
私とOSSの25年私とOSSの25年
私とOSSの25年
 
GPUが100倍速いという神話をぶち殺せたらいいな ver.2013
GPUが100倍速いという神話をぶち殺せたらいいな ver.2013GPUが100倍速いという神話をぶち殺せたらいいな ver.2013
GPUが100倍速いという神話をぶち殺せたらいいな ver.2013
 

Viewers also liked

Twitter graphics and installation tutorial
Twitter graphics and installation tutorialTwitter graphics and installation tutorial
Twitter graphics and installation tutorialKelly Sorenson
 
Creating an Interest List on Facebook
Creating an Interest List on FacebookCreating an Interest List on Facebook
Creating an Interest List on FacebookKelly Sorenson
 
Online writing for QC campus journalists
Online writing for QC campus journalistsOnline writing for QC campus journalists
Online writing for QC campus journalistswww.jobonsol.net
 
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 QCwww.jobonsol.net
 

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 Railsnebirhos
 
R getting spatial
R getting spatialR getting spatial
R getting spatialFAO
 
Geopy module in python
Geopy module in pythonGeopy module in python
Geopy module in pythonAshmita Dhakal
 
10. Getting Spatial
10. Getting Spatial10. Getting Spatial
10. Getting SpatialFAO
 
OSCON july 2011
OSCON july 2011OSCON july 2011
OSCON july 2011chelm
 
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.docxssuserd02b23
 
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.docxssuserd02b23
 
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ñaBig Data Spain
 
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 ServicesStephan Schmidt
 
Geo search introduction
Geo search introductionGeo search introduction
Geo search introductionkenshin03
 
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 casesAndrés de la Peña
 
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...DataStax
 
Udp socket programming(Florian)
Udp socket programming(Florian)Udp socket programming(Florian)
Udp socket programming(Florian)Flor Ian
 

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