AS distance
FROM
Photos INNER JOIN Geoname on photos.geonameid = geoname.geonameid
WHERE
earth_box(ll_to_earth (42.1, 19.1), 10000) @> ll_to_earth (latitude, longitude)
AND earth_distance(ll_to_earth (42.1, 19.1), ll_to_earth (latitude, longitude)) < 10000
ORDER BY
distance;
В краце, есть база с юзерами, у юзерами есть столбец ид города, и я сортирую этих юзеров по городам относительно тех кординат которые
я указал, в данном случае это (42.1, 19.1) . Запрос отрабатывает очень долго. Что можно сделать?
План запроса прикрепил
Postgis использовать
На сколько это более продуктивное решение? Сейчас запрос который мне нужен отрабатывает за 30-70 мс, в сколько раз будет лучше?
https://t.me/pgsql/303899 (И да, это не план, это какая-то плохая ксерокопия странных соображэний непонятной программы по поводу твоего плана).
select count(*) from places where earth_distance(ll_to_earth(places.coords[0], places.coords[1]), ll_to_earth(59.94, 30.13))<10000; count ------- 2907 (1 строка) Время: 362,881 мс select count(*) from places where places.geom::geography <-> ST_GeomFromEWKT('SRID=4326;POINT(30.13 59.94)')<10000; count ------- 2937 (1 строка) Время: 76,117 мс как-то так получается, ну и точность повыше
спасибо, понял все
Обсуждают сегодня