У меня есть многострочная строка, и я хочу преобразовать ее в строку строк, чтобы использовать некоторые функции, которые работают только с линиями строк. Я использовал ST_Dump()
и получил коллекцию моих геометрий. Если я объединю их вместе, я все равно получу многоканальную строку. Должен ли я получить Npoints и объединить их вместе или что-то, чтобы в итоге получить простую линейную строку? ST_LineMerge()
также не работает на моей мультилинстрине, она возвращает то же самое.
мой пример,
MultiLineString ((- +3,16420835153456 +55,9269166007097, -3,164222 55,926918), (- +3,1642070167833 +55,9269296196706, -3,16421351659546 55,9268662214904), (- +3,16421351659546 +55,9268662214904, -3,16421636372824 55,9268384509897), (- +3,16421636372824 +55,9268384509897, -3,16422182573761 55,9267851753802), (- +3,16422182573761 +55,9267851753802, -3,16422870102352 +55,926718114886 ), (- +3,16422870102352 55,926718114886, -3,16423309121073 +55,926675293667), (- +3,16423309121073 +55,926675293667, -3,16423565148822 55,9266503211093), (- +3,16423565148822 +55,9266503211093, -3,16424103159897 55,9265978443265), (- +3,16424103159897 55,9265978443265, -3,16424680776317 55,9265415044985), (- +3,16424680776317 +55,9265415044985, -3,16425267254583 +55,9264843002995 ), (- 3.16425267254583 55.9264843002995, -3.16425541048045 55.9264575949012), (- 3.16425541048045 55.9264575949012, -3.16426111146586 55.9264019883556),(-3,16426111146586 +55,9264019883556, -3,1642667032531 55,9263474469124), (- +3,1642667032531 55,9263474469124, -3,16426957768543 +55,9263194101362), (- +3,16426957768543 55,9263194101362, -3,16427488261739 +55,9262676666359), (- +3,16427488261739 55,9262676666359, -3,16428009893088 55,9262167875066), (- +3,16428009893088 +55,9262167875066, -3,164282741107 55,9261910161221), (-3,1642875546472 +55,9261440655823, -3,164282741107 55,9261910161221), (- +3,1642875546472 55,9261440655823, -3,16429466890915 +55,9260746741522), (- +3,16429466890915 55,9260746741522, -3,16430092974527 +55,9260136069079), (- +3,16430092974527 55,9260136069079, -3,16430822838418 55,9259424170929), (- +3,16430822838418 +55,9259424170929, -3,16431547242401 55,925871759829), (-3.16431547242401 55.925871759829, -3.16431448732505 55.9258328901507), (- 3.16431770120536 55.9257327846001, -3.16431547242401 55.925871759829), (- 3.164339 55,925777, -3,16431770120536 55,9257327846001))
Ответы:
Вы также можете использовать ST_SnapToGrid для исправления ваших данных, но вам нужно поиграться с параметрами, чтобы сделать это правильно.
источник
Вы уверены, что все ваши мультилинии, которые вы хотите конвертировать, могут быть конвертированы ?
В противном случае
ST_LineMerge
должно работать:ОБНОВИТЬ
Так вот, это предоставленная вами Multilinestring. Выглядит действительным отсюда.
Но при приближении для проверки вы можете ясно видеть, что это не может быть преобразовано в действительную линейную строку.
ДЕЙСТВИТЕЛЬНО:
ИНВАЛИД:
Но возьмите ДЕЙСТВИТЕЛЬНОЕ подмножество ваших очков, и оно работает просто отлично:
источник
Попробуйте использовать ST_SubDivide для разбиения больших геометрий на более мелкие после выпуска 2.2.0.
Я проверил и протестировал это на MultiLineString, чтобы разбить их в LineString.
https://postgis.net/docs/ST_Subdivide.html
источник