Преобразование MultiLinestring в Linestring с PostGIS?

16

У меня есть многострочная строка, и я хочу преобразовать ее в строку строк, чтобы использовать некоторые функции, которые работают только с линиями строк. Я использовал 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))

Antony
источник
Приведите нам пример этих многоканальных строк, которые вы хотите преобразовать, чтобы мы могли их протестировать.
CaptDragon

Ответы:

6

Вы также можете использовать ST_SnapToGrid для исправления ваших данных, но вам нужно поиграться с параметрами, чтобы сделать это правильно.

SELECT ST_AsText(
    ST_LineMerge(
        ST_SnapToGrid(
            ST_GeomFromText('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))'),
            0.001)
        )
    );
CaptDragon
источник
25

Вы уверены, что все ваши мультилинии, которые вы хотите конвертировать, могут быть конвертированы ?

Простая геометрия - это такая, которая не имеет аномальных геометрических точек, таких как самопересечение или самосогласование, и в первую очередь относится к 0 или 1-мерной геометрии.

В противном случае ST_LineMergeдолжно работать:

SELECT ST_AsText(ST_LineMerge(ST_GeomFromText('MULTILINESTRING((-29 -27,-30 -29.7,-36 -31,-45 -33),(-45 -33,-46 -32))')));

ОБНОВИТЬ

Так вот, это предоставленная вами Multilinestring. Выглядит действительным отсюда.

введите описание изображения здесь

Но при приближении для проверки вы можете ясно видеть, что это не может быть преобразовано в действительную линейную строку.

введите описание изображения здесь введите описание изображения здесь

ДЕЙСТВИТЕЛЬНО:

введите описание изображения здесь введите описание изображения здесь

ИНВАЛИД:

введите описание изображения здесь введите описание изображения здесь

Но возьмите ДЕЙСТВИТЕЛЬНОЕ подмножество ваших очков, и оно работает просто отлично:

SELECT ST_AsText(ST_LineMerge(ST_GeomFromText('MULTILINESTRING((-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))')));
CaptDragon
источник
Это на самом деле не правильно. LineStrings с самопересечениями все еще OGC-допустимы. Причина, по которой исходная MultiLineString не может быть преобразована в одну LineString, заключается в том, что она содержит 3 непересекающихся набора связанных вершин.
dr_jts
@dr_jts Правильно, так что это не значит, что LineString является недопустимым, но ввод неверен. Вы не можете конвертировать пересекающиеся линии. Таким образом, допустимый ввод строк будет без пересечений.
CaptDragon
0

Попробуйте использовать ST_SubDivide для разбиения больших геометрий на более мелкие после выпуска 2.2.0.

Я проверил и протестировал это на MultiLineString, чтобы разбить их в LineString.

https://postgis.net/docs/ST_Subdivide.html

rulhaniam
источник