Архив: Нужно создать запрос к базе PostgreSQL (PostGIS)

Бюджет 8$ / 500
руб
в месяц
Создан: 6 лет назад
Закрыт
Описание
Перекупов прошу не беспокоить. Спасибо.


Нужно создать запрос к базе PostgreSQL (PostGIS)

В базе содержатся геоданные Населенных пунктов в WKB формате.
В каждой строке в колонках d1, d2, d3 (компании доставок) установлены значения 1 или 0. 1 означает, что есть доставка в этом пункте. 0 означает, что нет.

Если в колонке d1 для какой либо строки стоит 0 (доставки нет) нужно найти ближайшую (по расстоянию) зону для этой компании, где доставка есть и записать id этой зоны в новую колонку d1_nearest (или обновить данные если колонка уже создана).

Таким же образом проставить id ближайших зон для других компаний доставки d2 = d2_nearest, d3 = d3_nearest.
Если установлена d1 = 1 (доставка есть), то записать в d1_nearest = "NULL".

Исходная таблица:
"id","name","geom","d1","d2","d3"
"7499","Рублёво","010300...B40","1","0","0" 
"7534","Троицк","010300...B40","1","0","0" 
"9629","Марьино","010300...B40","1","0","0" 
"9937","Внуково","010300...B40","1","1","0" 
"10724","Пыхтино","010300...B40","1","1","0" 
"10996","Боброво","010300...B40","1","1","0" 

Должно получиться в итоге:
"id","name","geom","d1","d2","d3"," d1_nearest","d2_nearest","d3_nearest"
"7499","Рублёво","010300...B40","1","0","0" ,"NULL","8248","8248"
"7534","Троицк","010300...B40","1","0","0" ,"NULL","9937","10723"
"9629","Марьино","010300...B40","1","0","0" ,"NULL","9937","10723"
"9937","Внуково","010300...B40","1","1","0" ,"NULL","NULL","10723"
"10724","Пыхтино","010300...B40","1","1","0" ,"NULL","NULL","10723"
"10996","Боброво","010300...B40","1","1","0" ,"NULL","NULL","11022"
И т.д.



Пример базы в аттаче.


Я делал так, но для этого варианта нужно две таблицы. Впринципе если сделать из этого цикл то подойдет и такой вариант, но нужно использовать одну таблицу и в ней же созвавать данные.

SELECT
t1.name As name,
t1.geom As geom,
t2.name As name,
t2.geom As geom,
ST_Distance(
ST_Transform(t1.geom::geometry, 3857),
ST_Transform(t2.geom::geometry, 3857)
) as dist
FROM cities11 As t1, cities10 As t2
WHERE t1.id = '7499' AND t1.id <> t2.id AND t2.d1 = '1'
ORDER BY ST_Distance(t1.geom,t2.geom) 
LIMIT 1
Категория

Похожие проекты

safe 
0 4
Необходимо разработать систему, которая: Подключается к API Diagnocat и iDent (через токены доступа). Получает данные о пациенте, результатах диагностики, снимках и назначениях. Автоматически формирует структурированный отчет по шаблону (включая врачей, этапы лечения, стоимость и описание процедур).......
 
0 0
Необходимо связать БД 1C:ERP с БД Outlook, MS Access, Битрикс24. Например при вводе нового сотрудника в 1С:ERP он должен автоматически появляться в вышеперечисленных БД....
4 месяца назад
 
0 1
Требуется реализация отчёта на кастомизированной 1С:УПП 1. 2, ТЗ и контрольный пример во вложении, 80% кода должно быть покрыто модульными тестами....
4 месяца назад
$7
0 2
Мне нужно копировать мой текст и вставлять в одну группу ВК с открытой стеной для публикации рекламы. Задача скрипта/сервиса/программы - примерно каждые 10 секунд брать мой текст и вставлять в эту группу. Я пробовал через одну программу, которая записывает действия мышки и потом повторяет, но она как-то......
6 месяцев назад
safe 
0 0
Написать прошивку для A94B114, используя 2 подобные рабочие прошивки. Все файлы есть....
$21
0 2
Нужно разархивировать файл архив. ujems, есть распаковщик, но выдает ошибку. Прислать пруфы(скрины)....
9 месяцев назад
safe 
0 1
Входные: Имеется скрипт по обработке email писем и добавление их в систему Redmine   Проблема: Система обработки этих писем написана некорректная и негибкая    Задача: Переписать логику обработки входящих писем, чтобы исключить их потерю при незначительных отклонениях от ожидаемой структуры....
$37
0 2
- В обязанности сотрудника входит поддержание мобильного приложения системы автоматизации бизнеса. - Работа сдельная: задачи выдаются на оценку, далее после согласования передаются на реализацию. - Заключаем договор и NDA (соглашение о неразглашении)....
$71
0 0
Информация о проекте: Проект включает в себя React Native приложение с Expo внутри которого находится webview с сайтом На устройствах с ОС IOS проблема с воспроизведением видео....
9 месяцев назад
safe 
0 0
Разрабатываю десктопные программы на языке Java,  а так же Java + SQL....
 
0 6
  1. Чтобы можно было писать описание события (без заголовка) - превью в списке берется N количества букв с начала. (в списке писать дату события и сколько осталось до него) . Выставление даты и времени напоминания и ИНТЕРВАЛА ПОВТОРА ОТ 1 МИНУТЫ! Выставлять количество повторов, далее напоминания прекращаются.......
safe 
0 5
Сайт arg2028t. beget. tech/. Нужно сделать вот такой калькулятор. airprint. by/outdoor/wide-format. и еще некоторые доработки....
safe 
0 7
Краткое описание: Мы ищем исполнителя для тестирования функционала мобильного приложения на платформе Android. Задача включает проверку основных функций приложения, таких как работа комнаты, передача видео, звука и чата, а также создание подробной отчетности о найденных ошибках.   Требования к исполнителю:......
safe 
0 12
Разработка чат-бота под ваши нужды....
$143
0 1
Oпpocы (1008pyб/чaс) Заходитe на сaйт: gonsù....
1 год назад
 
0 4
Требуется создать скрипт для premiere pro. Данная суть скрипта: в выделеном бине нужно что бы автоматически проставлялся in out ровно по серидине файла так что бы выделенная область была длиной 3 секунды. И требуется кнопка что бы работало через окно expressions. Проблема текущего в том что он не работает......
 
0 2
Нужно создать приложения под гемблинг/беттинг, на котлин. Приложение должно работать Firebase. Детали вышлю при обсуждение....
$21
0 4
Нужно разархивировать файл archive. ujems, есть распаковщик, но выдает ошибку. Прислать пруфы  ....
1 год назад
safe 
0 3
Разработать впн сервис ( Приложения на ios и android + сайт для оплаты подписки). Настройка Серверов. Оплата по договоренности. Работаем черед безопасную сделку....
1 год назад
Смотреть все