微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用 ST_GeomFromText

如何解决使用 ST_GeomFromText

我正在尝试创建一个多边形,而在 MysqL 中,这样做的方法是使用 ST_GeomFromText (polyGON (') 从我所看到的,但我需要能够使用变量而不仅仅是一个字符串。

例如。而不是

SELECT ST_GeomFromText('polyGON((-71.1776585052917 42.3902909739571,-71.1776820268866 42.3903701743239,-71.1776063012595 42.3903825660754,-71.1775826583081 42.3903033653531,-71.1776585052917 42.3902909739571))');

使用类似的东西

SET @p1 = POINT(-71.1776585052917,42.3902909739571);
SET @p2 = POINT(-71.1776820268866,42.3903701743239);
SET @p3 = POINT(-71.1776063012595,42.3903825660754);
SET @p4 = POINT(-71.1775826583081,42.3903033653531);

SELECT ST_GeomFromText('polyGON(@p1,@p2,@p3,@p4,@p1)');

关于如何实现这一目标的任何想法? 附注我第一次在这里提问。

解决方法

不确定这是否是最好的解决方案,但我修复它的方式是使用这种方法。

    SET @p1 = ST_GeometryFromText(CONCAT('POINT(',(lat-@POINT_DISTANCE),' ',(lon+@POINT_DISTANCE),')'),4326);
    SET @p2 = ST_GeometryFromText(CONCAT('POINT(',(lat+@POINT_DISTANCE),4326);
    SET @p3 = ST_GeometryFromText(CONCAT('POINT(',(lon-@POINT_DISTANCE),4326);
    SET @p4 = ST_GeometryFromText(CONCAT('POINT(',4326);

    SET @str = CONCAT('POLYGON((',ST_X(@p1),ST_Y(@p1),',ST_X(@p2),ST_Y(@p2),ST_X(@p3),ST_Y(@p3),ST_X(@p4),ST_Y(@p4),'))');

SET @POLY = ST_GeomFromText(@str,4326);
     
SELECT id FROM user_details force index(user_details_location) WHERE ST_CONTAINS(@POLY,user_details.location);

基本上只是很多连接,而且似乎有效。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。