What is the fastest way to find a big table in radius mysql (latitude longitude)

Currently I have several tables with 100k rows. I am trying to find the following data.

SELECT
* , SQRT(POW(69.1 * (latitude-'49.1044302'), 2) + POW(69.1 * ('-122.801094'-longitude) * COS(latitude / 57.3), 2)) AS distance
FROM stops< br />HAVING distance <5
ORDER BY distance limit 100

But currently this method will slow down under high load. Some queries take 20 seconds to complete.

If anyone knows any better optimization method, it would be great.

First of all, if You have a lot of geospatial data, you should use mysql’s geospatial extensions instead of calculations like this. Then, you can use create spatial indexes to speed up many queries, and you don’t have to write long extraction queries as described above.

Using a comparison with ST_Distance or creating a geometry with a radius of interest as well as ST_within may give you good results and may be much faster than current. However, the best way to achieve this is and The fastest way, ST_Dwithin has not been implemented in mysql.

Currently I have several tables with 100k rows. I am trying to find the following data.

SELECT
*, SQRT(POW(69.1 * (latitude-'49.1044302'), 2) + POW(69.1 * ('-122.801094'-longitude) * COS( latitude / 57.3), 2)) AS distance
FROM stops
HAVING distance <5
ORDER BY distance limit 100

But currently this method will Slow. Some queries take 20 seconds to complete.

If anyone knows any better optimization method, this would be Great.

First of all, if you have a lot of geospatial data, you should use mysql’s geospatial extension instead of calculations like this. Then, you can Use create spatial indexes to speed up many queries, and you don’t have to write long extraction queries as described above.

Use a comparison with ST_Distance or create a geometry with a radius of interest and ST_within may give you Brings good results, and may be much faster than the current one. However, the best and fastest way to achieve this goal, ST_Dwithin has not yet been implemented in mysql.

p>

WordPress database error: [Table 'yf99682.wp_s6mz6tyggq_comments' doesn't exist]
SELECT SQL_CALC_FOUND_ROWS wp_s6mz6tyggq_comments.comment_ID FROM wp_s6mz6tyggq_comments WHERE ( comment_approved = '1' ) AND comment_post_ID = 2990 ORDER BY wp_s6mz6tyggq_comments.comment_date_gmt ASC, wp_s6mz6tyggq_comments.comment_ID ASC

Leave a Comment

Your email address will not be published.