Один объект на местности — один в базе. Ничего избыточного.
Оккам скорее переворачивается от схемы Karlsruhe, c кучей повторяющихся по сотне раз тегов addr:street, addr:region, addr:country…
Komяpa, в России полно деревень, названия которых повторяются внутри района - тогда сельсовет включается в адрес. В КЛАДР-е они так и обозначены: Новая (Еласовский с/с), Новая (Троицко-Посадский с/с)
Что касается адреса на вее, как к вею мембер is_in назначить? Адресация-то снизу.
Дак а как это решает проблему двух адресов у здания?
А понял, housenumbers = addr:streetnumbers - указывает на то под каким атрибутом прячется номер дома под которым он входит в улицу, только это ни разу не айс, и вот почему:
Для жилишьных комплексов еще работает но для нумерации угловых домов в городе вам понадобиться для каждой улицы вводить свое (уникальное в рамках города) значение тэга housenumbers что не удобно, прежде всего по тому что очень не универсально.
is_in используется как раз для того чтобы не формировать для каждой улицы уникальное имя тэга показывающего под каким номером дом входит в улицу.
P.S. Что на счет избыточности: хотим сократить объем данных - избавляемся от избыточности, хотим сократить количество вычислений - вводим избыточность.
Для этого в любом случае нужен какой-то костыль. Либо просто включить как дополнительный уровень адресации, но с пометкой (какой-нибудь тег), что использовать только при коллизиях.
Не путайте адресацию с административным подчинением.
dkiselev, если у дома один адрес - ничего на него плодить не нужно, просто включить с ролью house в улицу. Если больше одного - делаются отношения на каждый адрес с включением их в нужные улицы. Всё на самом деле не так сложно.
Адрес объекта — это тоже объект. Причём он может даже не соответствовать ничему материальному, например «владение» с номером, которое является просто куском территории.
Кстати, тот же вопрос про внутригородские районы: в Москве, например, есть четыре улицы 8 марта.
И если “в любом случае нужен какой-то костыль” - это УЖЕ не универсальная схема.
Vovanium, кусок территории - вполне себе материальный объект
И ещё: в адресе используют не с/с (не смотрите в КЛАДР, это вредно), а п/о, а оно не обязано совпадать с с/с. Пример: с/с с/п Погореловка (КЛАДР 4002500009900) получает почту через п/о Крюково (КЛАДР 4002500005700).
Любая модель будет в чём-то неунивесальной. Схема Карлсруэ ещё менее универсальна. Но можно расширить схему, чтобы она покрывала нужные нам схемы адресации.
В чём различаются адреса, относящиеся к различным улицам 8 марта?
Это не материальный объект в том смысле, что его никак нельзя определить визуально — земля во владении и вокуг на вид одинаковая.
Имеем то же, что и addr:housenumber, addr:housenumber2, только в неуниверсальном виде.
Такую конструкцию не получится использовать для домов с 3-мя и более адресами.
О какой вложенности можно говорить, к примеру, дома в улицу? Или наоброт, Москвы в Московскую область? Вложенность — частое, но не обязательное и недостаточное свойство.
Если мы объединяем несколько районов в область, или наоборот, разбиваем область на районы, то ту самую вложенность получаем автоматически — было бы странно, если бы a не принадлежало множеству (не было бы «вложенным» в) {a, b, c}. Её не надо «учитывать» — это просто очевидное следствие иерархии.
Vovanium, а я раньше и говорил, что улица - это не “уровень иерархии”, а просто группировка. А базовый объект адресации - населённый пункт.
То есть дом/участок принадлежит к населённому пункту, а адресуется внутри этого н/п с помощью улиц. Или кварталов. Или микрорайонов. Или вообще непосредственно.