MultiLineString
MultiLineString
是零個或多個或 geometry
geographyLineString實例的集合。
MultiLineString 執行個體
下圖顯示 MultiLineString
執行個體的範例。
如本圖所示:
圖 1 是簡單的
MultiLineString
實例,其界限是其兩LineString
個元素的四個端點。圖 2 是簡單
MultiLineString
執行個體,因為只有LineString
元素的端點才會相交。 界限是兩個非重疊的端點。圖 3 是非簡單的
MultiLineString
執行個體,因為它的其中一個LineString
元素的內部會相交。 此MultiLineString
執行個體的界限是這四個端點。圖 4 是非簡單、非封閉的
MultiLineString
執行個體。圖 5 是簡單、非封閉的
MultiLineString
。 它不會關閉,LineStrings
因為它的元素並未關閉。 因為任何LineStrings
執行個體的內部都不相交,所以它是簡單的。圖 6 是簡單、封閉的
MultiLineString
執行個體。 它是封閉的,因為它的所有元素都是封閉的。 因為它的所有元素在內部都不相交,所以它是簡單的。
已接受的執行個體
若要接受 MultiLineString
執行個體,則該執行個體必須是空的,或是僅由可接受的 LineString
執行個體組成。 如需已 LineString
接受實例的詳細資訊,請參閱 LineString。 以下為可接受之 MultiLineString
執行個體的範例。
DECLARE @g1 geometry = 'MULTILINESTRING EMPTY';
DECLARE @g2 geometry = 'MULTILINESTRING((1 1, 3 5), (-5 3, -8 -2))';
DECLARE @g3 geometry = 'MULTILINESTRING((1 1, 5 5), (1 3, 3 1))';
DECLARE @g4 geometry = 'MULTILINESTRING((1 1, 3 3, 5 5),(3 3, 5 5, 7 7))';
下列範例會擲回 System.FormatException
,因為第二個 LineString
執行個體無效。
DECLARE @g geometry = 'MULTILINESTRING((1 1, 3 5),(-5 3))';
有效的執行個體
MultiLineString
執行個體必須符合下列準則,才會是有效的:
組成
MultiLineString
執行個體的所有執行個體必須都是有效的LineString
執行個體。組成
LineString
執行個體的任兩個MultiLineString
執行個體都不可在間隔上重疊。LineString
執行個體只能在有限的點數內彼此交集或接觸,或是接觸其他LineString
執行個體。
下列範例示範三個有效的 MultiLineString
執行個體和一個無效的 MultiLineString
執行個體。
DECLARE @g1 geometry = 'MULTILINESTRING EMPTY';
DECLARE @g2 geometry = 'MULTILINESTRING((1 1, 3 5), (-5 3, -8 -2))';
DECLARE @g3 geometry = 'MULTILINESTRING((1 1, 5 5), (1 3, 3 1))';
DECLARE @g4 geometry = 'MULTILINESTRING((1 1, 3 3, 5 5),(3 3, 5 5, 7 7))';
SELECT @g1.STIsValid(), @g2.STIsValid(), @g3.STIsValid(), @g4.STIsValid();
@g4
無效,因為第二個 LineString
執行個體與第一個 LineString
執行個體於間隔處重疊。 兩者以無限點數接觸。
範例
下列範例會建立包含兩個具有 SRID 0 之 geometry``MultiLineString
元素的簡單 LineString
執行個體。
DECLARE @g geometry;
SET @g = geometry::Parse('MULTILINESTRING((0 2, 1 1), (1 0, 1 1))');
若要使用不同的 SRID 來具現化這個執行個體,請使用 STGeomFromText()
或 STMLineStringFromText()
。 您也可以使用 Parse()
,然後修改 SRID,如下列範例所示。
DECLARE @g geometry;
SET @g = geometry::Parse('MULTILINESTRING((0 2, 1 1), (1 0, 1 1))');
SET @g.STSrid = 13;
另請參閱
STLength (geometry 資料類型)
STIsClosed (geometry 資料類型)
LineString
空間資料 (SQL Server)