Mysqlgis空间数据库功能详解学习.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Mysqlgis空间数据库功能详解学习

? Mysql gis 空间数据库功能详解学习 mysql gis 中文:/doc/refman/5.1/zh/spatial-extensions-in-mysql.html#gis-class-polygon? 下文为收集资料整理后,并测试后结果 当前只有MyISAM引擎的数据表支持地理空间数据的存储 建表: CREATE?DATABASE?geodatabase; USE?geodatabase; CREATE?TABLE?test( ??id?INT?PRIMARY?KEY?AUTO_INCREMENT, ??name?VARCHAR(128)?NOT?NULL, ??pnt?POINT, ??line?LINESTRING, ??pgn?POLYGON )ENGINE=MyISAM; 添加空间列,geom表里添加可以存储point类型数据 ALTER TABLE geom ADD pt POINT; 用以下SQL插入一条空间数据 INSERT?INTO?`test`?VALUES( null, a?test?string, POINTFROMTEXT(POINT(15?20)), LINESTRINGFROMTEXT(LINESTRING(0?0,?10?10,?20?25,?50?60)), POLYGONFROMTEXT(POLYGON((0?0,10?0,10?10,0?10,0?0),(5?5,7?5,7?7,5?7,?5?5))) ); 这里也可以用通行的GEOMFROMTEXT函数实现WKT到数据库内部几何格式的转换。而GEOMFROMWKB函数用于转换WKB。 INSERT INTO `gis` VALUES( null, a test strin222g, GEOMFROMTEXT(POINT(15 20)), GEOMFROMTEXT(LINESTRING(0 0, 10 10, 20 25, 50 60)), GEOMFROMTEXT(POLYGON((0 0,10 0,10 10,0 10,0 0),(5 5,7 5,7 7,5 7, 5 5))) ) 这个函数很有用:Envelope Envelope(g) ? ? ? ? ? ? 返回几何值g的最小边界矩形(MBR)。结果以Polygon值的形式返回。 多边形(polygon)是由边界框的顶点定义的: POLYGON((MINX MINY, MAXX MINY, MAXX MAXY, MINX MAXY, MINX MINY)) mysql SELECT AsText(Envelope(GeomFromText(LineString(1 1,2 2)))); +-------------------------------------------------------+ | AsText(Envelope(GeomFromText(LineString(1 1,2 2)))) | +-------------------------------------------------------+ | POLYGON((1 1,2 1,2 2,1 2,1 1)) | +-------------------------------------------------------+ 或者多个点面集合: SELECT AsText( Envelope( GeomFromText(GeometryCollection(Point(10 2),Point(9 9),LineString(2 2, 3 30),LineString(200 200, 3 30),Polygon((400 300,10 0,10 10,0 10,400 300)),Point(100 100)) ) ) ) ; 用以下SQL从数据表中获得空间数据 SELECT?id,name,ASTEXT(pnt),ASTEXT(line),ASTEXT(pgn)?from?`test`; ASTEXT函数的功能与GEOMFROMTEXT的功能恰好相反,就是将数据从内部格式转换为WKT;相应的ASBINARY可以转换为WKB。 MYISAM.这样就创建成功了 ?? ? 2?在geom表里添加可以存储point类型数据 ALTER TABLE geom ADD pt POINT; ? ? 3?向point列添加标准的空间数据 ? 4?数据已经存进去了,只要把它去出来,第三个问题也就解决啦! 这是从mysql的空间数据列中取出标准的wtk格式空间数据的函数AsText(). 现在我需要的功能是查找一辆车在

文档评论(0)

peain + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档