I wanted to merge two polygon geometries in a
SpatiaLite database (an example is the land feature layer shown in the screenshot below) into a single geometry using
QGIS.
data:image/s3,"s3://crabby-images/61ddb/61ddb7dae021d553bbf8f243a32dd24904d11bc9" alt="" |
Two SpatiaLite polygons labelled with the primary key id number. |
In
QGIS, the usual command to perform this task is the
Union command, but unfortunately it creates only Shapefiles. The alternative is to use the
QSpatiaLite plug-in and run some SQL commands to do the job. The following steps show how to merge two polygons into one polygon using the SpatiaLite
GUnion operator.
- In QGIS, select Database | SpatiaLite | QSpatiaLite.
The QSpatiaLite dialog box appears.
data:image/s3,"s3://crabby-images/ca08a/ca08ad9d3c47d3ed2a8578acca92cd7a68137344" alt=""
- Note down the primary key numbers or any suitable identifier of the polygons to be merged, e.g. pkuid 10 and 20.
- In the SQL tab field, type in the SQL command.
SELECT GUNION
(
(SELECT geometry FROM land WHERE pkuid = 10)
,
(SELECT geometry FROM land WHERE pkuid = 20)
)
AS geometry
data:image/s3,"s3://crabby-images/91809/91809b7645f2123ee8632909a3d16b3732afdafe" alt=""
- Click Run SQL.
A temporary new geometry object is created.
data:image/s3,"s3://crabby-images/58ed1/58ed124b7e45cbc9e034be3265835928271164f7" alt=""
Note: if the above SQL command execution is successful, then it is fine to proceed to create a new merged polygon feature and delete the original two polygons.
- In the SQL tab, type in the following SQL command to create and insert a merged polygon feature record.
INSERT INTO land (geometry)
SELECT GUNION
(
(SELECT geometry FROM land WHERE pkuid = 10)
,
(SELECT geometry FROM land WHERE pkuid = 20)
)
AS geometry
data:image/s3,"s3://crabby-images/3cd16/3cd16b818f57a3c0126135ee78688d094750acc7" alt=""
- Click Run SQL.
A new row is inserted into the land table.
data:image/s3,"s3://crabby-images/8f9d2/8f9d2bce76aa2ec4d1ac2db6e232c25dbb7e756e" alt=""
- In the SQL tab, type in the SQL command to delete the original two polygon features.
DELETE FROM land WHERE pkuid = 10 OR pkuid = 20
data:image/s3,"s3://crabby-images/75c7e/75c7ec7aa1c9dc4844eb23bf0eb1aabdb3bec286" alt=""
- Click Run SQL.
The original polygon features are deleted.
- Refresh the map view by toggling the land feature display off and on.
The merged polygon is displayed.
data:image/s3,"s3://crabby-images/97aa5/97aa5e510b5199a16c297dca593821664ac91fe5" alt=""
No comments:
Post a Comment