172 похожих чатов

У меня есть запрос SELECT *, ROUND(earth_distance(ll_to_earth(42.1, 19.1), ll_to_earth(latitude, longitude))::NUMERIC, 2)

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) . Запрос отрабатывает очень долго. Что можно сделать?
План запроса прикрепил

5 ответов

32 просмотра

Postgis использовать

punkin ☘- Автор вопроса
Anton Morozov
Postgis использовать

На сколько это более продуктивное решение? Сейчас запрос который мне нужен отрабатывает за 30-70 мс, в сколько раз будет лучше?

https://t.me/pgsql/303899 (И да, это не план, это какая-то плохая ксерокопия странных соображэний непонятной программы по поводу твоего плана).

punkin ☘
На сколько это более продуктивное решение? Сейчас ...

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

punkin ☘- Автор вопроса

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта