A typical GIS spatial query is to find all the point features in a buffer around a linear feature. This can be easily achieved using SpatiaLite database also. The following illustrates the workflow using two SpatiaLite feature tables - nodes and segments.
data:image/s3,"s3://crabby-images/81fbb/81fbb22bb2327bfb8205a493ba4a944631aacec9" alt=""
Using any SpatiaLite interface (graphical or command line interface), simply type in the following SQL statement to create a 50 meter buffer around the line segment feature using the spatial operator ST_Buffer:
SELECT ST_Buffer(Geometry, 50) AS buffer
FROM segments
WHERE name='line1'
data:image/s3,"s3://crabby-images/f86b3/f86b354cd41744902ba63472418223fa4dcb1077" alt=""
The screenshot below shows how the 50 meter buffer looks like on a map.
data:image/s3,"s3://crabby-images/61f6b/61f6bbd5913e1213c14ba307e8c1c1be76dd1f6d" alt=""
To identify all the point nodes within the buffer, we can wrap the buffer statement in a more complex SQL statement:
SELECT a.* FROM nodes AS a,
(
SELECT buffer FROM
(
SELECT ST_Buffer(Geometry, 50) AS buffer
FROM segments
WHERE name='line1'
) AS b
)
WHERE ST_Contains(buffer, a.Geometry)
data:image/s3,"s3://crabby-images/dcdd8/dcdd8842e202c52ea217935ac26d9e9af590d6dd" alt=""
The screenshot shows how the results are like on a map.
data:image/s3,"s3://crabby-images/45ac1/45ac171cfdf0566201ac1b18d5fca0b634b9d843" alt=""
2 comments:
Hi Hardikgis,
try this
select a.* from linka as a, (
select buffergeometry from (
select st_buffer(transgeometry, 500) as buffergeometry from
(
select st_transform(geometry,26910) as transgeometry from pointa
)
)
)
where st_contains(buffergeometry, a.geometry)
Just replace 26910 with your projected SRID, and 500 with your buffer distance in meters.
rg
Hardikgis,
I am quite certain the sql syntax is correct, as I tested it on a real dataset. So, it must be either your data, or the software that is causing your erroneous result. Would you like to send a representative set of data to me by email or dropbox for me to look at?
Post a Comment