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 мс как-то так получается, ну и точность повыше
спасибо, понял все
Обсуждают сегодня