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