data:image/s3,"s3://crabby-images/e24ba/e24ba472e85dc459e8951fa1608ada58b9c42fe1" alt=""
Having read (and tried out) John's first impression of SQL 2008 Spatial, I went about extending the dataset to try some of the other capabilities of SQL Server 2008's geography datatypes and functions.
The following tables were added:
data:image/s3,"s3://crabby-images/1ed7b/1ed7b3019c1b25f0a3edd7d3ca3a1c30f13e72d2" alt=""
and the data inserted. The KMZ file was parsed with the XSD generator and C# (similar to John's example);
data:image/s3,"s3://crabby-images/38ead/38eadda31193f2ad8281032c7657e07365d26e1e" alt=""
the CSV files were opened in Excel
data:image/s3,"s3://crabby-images/a5130/a51303889114ce92fb3cf74da68debaf35dd4296" alt=""
and INSERT statements generated.
data:image/s3,"s3://crabby-images/522ee/522eeaa5ebe15f11ae6adb26d3b4270e932986a4" alt=""
It's worthwhile noting that the data import didn't go 100% according to plan. Some electorates consist of more than one polygon (to be unioned together, I suppose) - I've only imported the first Polygon for each electorate in the KMZ file. Other electorates failed with SQL errors - still to determine why the coordinates listed cause SQL Server to fail (no, it's not the ring-orientation...).
The following queries were then possible...
select state
, electorate
, ROUND(Location.STArea()/1000000,0) As [AreaSqKm]
from electorates
data:image/s3,"s3://crabby-images/3a827/3a82712023fb74af3cb4a60c9452c4c0686bac3c" alt=""
select state
, electorate
, COUNT(p.Title) AS [NumberOfPostcodes]
, ROUND(e.Location.STArea()/1000000,0) AS [AreaSqKms]
, ROUND(e.Location.STArea()/1000000 /COUNT(p.Title),0) AS [AreaPerPostcodeSqKm]
from electorates e
inner join Postcodes p on (p.Location.STIntersects(e.Location) = 1)
group by State, electorate, e.Location.STArea()/1000000
data:image/s3,"s3://crabby-images/b83a9/b83a9148357c51709c234a2ff87ee61cea0493e7" alt=""
select state
, e.electorate
, p.Title as [Suburb]
, COUNT(pp.PollingPlaceID) AS NumberPollingPlaces
from electorates e
inner join Postcodes p on (p.Location.STIntersects(e.Location) = 1)
inner join PollingPlaces pp on (pp.Electorate = e.Electorate AND pp.Postcode = p.Postcode)
group by state, e.electorate, p.Title
data:image/s3,"s3://crabby-images/4b44f/4b44f0027573e56904df8bea85c180dc7752c369" alt=""
select state
, e.electorate
, ROUND(e.Location.STArea(),0) AS [AreaSqMs]
, SUM(ppv.TotalVotes) AS [TotalVotes]
, ROUND(e.Location.STArea() /(1+SUM(ppv.TotalVotes)),0) AS [AreaPerVoterM]
from electorates e
inner join Postcodes p
on (p.Location.STIntersects(e.Location) = 1)
inner join PollingPlaces pp
inner join PollingPlaceVotes ppv on ppv.PollingPlaceId = pp.PollingPlaceId
on (pp.Electorate = e.Electorate AND pp.Postcode = p.Postcode)
group by State, e.electorate, e.Location.STArea()
data:image/s3,"s3://crabby-images/1f9bf/1f9bf4ac77598e187817f197bcb265d63e258d34" alt=""
It is this query I've attempted to map at the top of the post - hopefully demonstrating finding points inside a polygon to group postcode data together for couting and summation; and using the area function to determine 'density'.
The next step is to get the POLYGON data into a map (as well as the POINTS)...
select electorate, Location.STAsText() as PolygonWKT
from electorates order by electorate
data:image/s3,"s3://crabby-images/80f1f/80f1fc318ac7212664eb3bb85f29152aed7010aa" alt=""
No comments:
Post a Comment
Note: only a member of this blog may post a comment.