当前位置: 首页 > news >正文

滕州英文网站建设中国平面设计和网站建设

滕州英文网站建设,中国平面设计和网站建设,网店名字创意,网站底部放什么PostGIS学习教程九#xff1a;空间连接 空间连接#xff08;spatial joins#xff09;是空间数据库的主要组成部分#xff0c;它们允许你使用空间关系作为连接键#xff08;join key#xff09;来连接来自不同数据表的信息。我们认为“标准GIS分析”的大部分内容可以表示…PostGIS学习教程九空间连接 空间连接spatial joins是空间数据库的主要组成部分它们允许你使用空间关系作为连接键join key来连接来自不同数据表的信息。我们认为“标准GIS分析”的大部分内容可以表示为空间连接。 在上一节中我们通过两个步骤探索了空间关系首先我们提取了’Broad St宽街的地铁站点然后我们用这个地铁站点来问更多的问题如Broad St’站位于哪个社区 使用空间连接我们可以只通过一个步骤来回答这个问题检索有关地铁站及其所在社区的信息 SELECTsubways.name AS subway_name,neighborhoods.name AS neighborhood_name,neighborhoods.boroname AS borough FROM nyc_neighborhoods AS neighborhoods JOIN nyc_subway_stations AS subways ON ST_Contains(neighborhoods.geom, subways.geom) WHERE subways.name Broad St;我们本可以把每个地铁站都连接到它所在的社区但在这种情况下我们只想知道其中一个地铁站的信息。 任何在两个表之间提供true/false关系的函数都可以用来驱动空间连接但最常用的函数是ST_Intersects、ST_Contains和ST_DWithin。 文章目录 PostGIS学习教程九空间连接一、连接和汇总二、高级连接三、空间连接练习 一、连接和汇总 JOIN和GROUP BY的组合支持通常在GIS系统中的某些分析。 例如“曼哈顿行政区的各个社区的人口和种族构成是什么”这个问题将人口普查中的人口信息与社区的几何信息结合在一起社区信息只限制在曼哈顿的一个行政区中。 SELECTneighborhoods.name AS neighborhood_name,Sum(census.popn_total) AS population,100.0 * Sum(census.popn_white) / Sum(census.popn_total) AS white_pct,100.0 * Sum(census.popn_black) / Sum(census.popn_total) AS black_pct FROM nyc_neighborhoods AS neighborhoods JOIN nyc_census_blocks AS census ON ST_Intersects(neighborhoods.geom, census.geom) WHERE neighborhoods.boroname Manhattan GROUP BY neighborhoods.name ORDER BY white_pct DESC;这里发生了什么从理论上讲数据库在内部对实际运行机制进行了优化发生的情况如下: 1.JOIN子句创建了一个虚拟表其中包含来自neighborhoods表和census表的列。 2.WHERE子句将我们的虚拟表筛选为仅保留有关曼哈顿行政区的记录。 3.结果记录按neighborhood name分组并通过聚合函数Sum()计算人口数 4.在对最后的数字进行一些算术和格式化之后我们的查询就会输出百分比。 注意JOIN子句组合了两个FROM子句中的数据表默认情况下数据库使用的是INNER JOIN连接类型但还有其他四种连接类型有关详细信息请参阅PostgreSQL文档中的join_type的定义。 我们还可以使用距离测试作为连接键以创建汇总的“半径内所有项”查询。让我们使用距离查询来探索纽约的种族地理。 首先让我们了解一下这个城市的基本种族构成。 SELECT100.0 * Sum(popn_white) / Sum(popn_total) AS white_pct,100.0 * Sum(popn_black) / Sum(popn_total) AS black_pct,Sum(popn_total) AS popn_total FROM nyc_census_blocks;因此在纽约的800万人口中大约44%的人被记录为”白人“26%的人被记录为”黑人“。 艾灵顿公爵曾经唱过这样一首歌你/必须乘A-train/去哈莱姆区Harlem的糖山Sugar Hill。正如我们早些时候看到的哈莱姆地区拥有曼哈顿Manhattan最多的非裔美国人80.5%。杜克Duke的A-train也是这样的吗 首先请注意nyc_subway_stations表routes字段的内容是我们感兴趣的用于查找A-train的内容。里面的值有点复杂。 SELECT DISTINCT routes FROM nyc_subway_stations;注意DISTINCT关键字从结果中消除重复的行。如果没有DISTINCT关键字上面的查询将标识491个结果而不是73个。 所以要找到A-train我们需要在routes列中有’A’的所有行记录。我们可以通过多种方法来实现这一点但今天我们将使用strpos(routes, ‘A’)它只有当’A’在routes列中才会返回非零数。 SELECT DISTINCT routes FROM nyc_subway_stations AS subways WHERE strpos(subways.routes,A) 0;现在让我们计算一下距A-train线200米以内的种族构成 SELECT100.0 * Sum(popn_white) / Sum(popn_total) AS white_pct,100.0 * Sum(popn_black) / Sum(popn_total) AS black_pct,Sum(popn_total) AS popn_total FROM nyc_census_blocks AS census JOIN nyc_subway_stations AS subways ON ST_DWithin(census.geom, subways.geom, 200) WHERE strpos(subways.routes,A) 0;因此可以得出结论A-train服务的区域的种族构成与城市其他区域的种族构成并没有太大的不同。 二、高级连接 在上面的最后部分我们看到A-train服务的区域的种族构成与城市其他区域的种族构成并没有太大的不同。有没有哪些地铁的服务区域的种族构成与纽约整个城市的种族构成差异较大 为了回答这个问题我们将在查询中添加另一个连接以便可以同时计算多条地铁线路的构成。要做到这一点我们需要创建一个新的表遍历我们想要汇总的所有行。 CREATE TABLE subway_lines ( route char(1) ); INSERT INTO subway_lines (route) VALUES(A),(B),(C),(D),(E),(F),(G),(J),(L),(M),(N),(Q),(R),(S),(Z),(1),(2),(3),(4),(5),(6),(7);现在我们可以将subway lines连接到原始查询中。 SELECTlines.route,100.0 * Sum(popn_white) / Sum(popn_total) AS white_pct,100.0 * Sum(popn_black) / Sum(popn_total) AS black_pct,Sum(popn_total) AS popn_total FROM nyc_census_blocks AS census JOIN nyc_subway_stations AS subways ON ST_DWithin(census.geom, subways.geom, 200) JOIN subway_lines AS lines ON strpos(subways.routes, lines.route) 0 GROUP BY lines.route ORDER BY black_pct DESC;如前所述连接创建了一个虚拟表其中包含在JOIN ON约束范围内可用的所有的连接的行记录然后将这些行记录分组。ST_DWithin可确保计算中仅包括靠近地铁站的人口普查区块。 三、空间连接练习 下面是我们之前所看到的一些函数的汇总它们应该对练习有用 同时请记住我们的数据库中现有的数据表 nyc_census_blocks name, popn_total, boroname, geom nyc_streets name, type, geom nyc_subway_stations name, routes, geom nyc_neighborhoods name, boroname, geom 练习: ①小意大利Little Italy社区有什么地铁站它在哪些地铁线路上 SELECT s.name, s.routes FROM nyc_subway_stations AS s JOIN nyc_neighborhoods AS n ON ST_Contains(n.geom, s.geom) WHERE n.name Little Italy;②6-train服务哪些社区?提示nyc_subway_stations表中的routes列具有类似B,D,6,V和C,6的值 SELECT DISTINCT n.name, n.boroname FROM nyc_subway_stations AS s JOIN nyc_neighborhoods AS n ON ST_Contains(n.geom, s.geom) WHERE strpos(s.routes,6) 0;注意我们使用DISTINCT关键字从结果集中删除在一个社区中的多个地铁站的重复记录。 ③9/11事件后Battery Park社区附近将禁止入内几天那么要疏散多少人呢 SELECT Sum(popn_total) FROM nyc_neighborhoods AS n JOIN nyc_census_blocks AS c ON ST_Intersects(n.geom, c.geom) WHERE n.name Battery Park;④Upper West Side和Upper East Side的人口密度是多少 SELECTn.name,Sum(c.popn_total) / (ST_Area(n.geom) / 1000000.0) AS popn_per_sqkm FROM nyc_census_blocks AS c JOIN nyc_neighborhoods AS n ON ST_Intersects(c.geom, n.geom) WHERE n.name Upper West Side OR n.name Upper East Side GROUP BY n.name, n.geom;
http://www.dnsts.com.cn/news/105961.html

相关文章:

  • 家里电脑做网站服务器seo搜索优化公司报价
  • 为何网站打开慢站建设培训学校
  • 书画展示网站模板群晖 做网站
  • 大型门户网站建设工作总结万网的app叫什么
  • 北京pk10盘制作网站建设网站建设费 无形资产
  • 网站开发的嘉兴小程序定制
  • 坪山网站建设信息搜索引擎优化自然排名的区别
  • 珠海网站设计哪家好哈尔滨信息网招聘
  • 天津做网站哪家服务好域名请记住222922
  • 网站建设的基本内容浏览器怎么下载视频
  • 购门网站建设做微信的网站叫什么
  • mooc网站开发案例深圳高端网站建设公司
  • 阿里云nas做网站南阳最新通知今天
  • 数据共享网站建设凡科做的免费网站
  • 企业网站建设规划的基本原则phpcms旅游网站模板
  • 企业建站系统漏洞网站建设 电话
  • 北京泰达建设有限公司网站专注建设高端网站
  • 天津大邱庄网站建设公司网页设计模板html代码登录代码
  • 凤台县美丽乡村建设网站做图的模板下载网站有哪些
  • 网站关健词排名微擎可以做企业网站吗
  • 响应式网站 英语打电话来说做网站 然后答应了
  • 专业的网站开发公司电话广州做一个网站多少钱
  • 云霄县建设局网站投诉wordpress首页模板是哪个文件
  • 青岛高创网站建设公司网站建设中心
  • 网站建设的基本流程和步骤汕头手机端建站模板
  • 上海找做网站公司哪家好网站开发工程师的要求
  • 怀柔做网站阿里云网站如何做淘宝客
  • 区域网站查询Python做网站 性能
  • 青海省公路工程建设总公司网站dw网页设计报告
  • 银联支付网站建设营销方案和销售思路