我使用了http://dev.mysql.com/tech-resources/articles/4.1/gis-with-mysql.html的教程
所以我创建了两个表,插入了一些数据,当我试图使用这样的脚本获取一些数据
SELECT
c.cab_driver,
ROUND(GLength(LinestringFromWKB(Linestring(AsBinary(c.cab_loc),
AsBinary(a.address_loc)))))
AS distance
FROM cab c, address a
WHERE a.address = 'Foobar street 110'
ORDER BY distance ASC LIMIT 1;
我收到一个错误:“错误代码:1367非法非几何’aswkb(c.cab_loc)’值解析过程中找到”
有什么建议?
我在这个问题上取得了一些进展,我试着跑了
SELECT
asbinary(c.cab_loc)
FROM usercoordinates.cab c;
我在每一行都得到NULL,但如果我使用astext,我会在每一行得到POINT(…)
最后我得到了它,也许不是最好的解决方案
SELECT
c.cab_driver,
Round(glength(LinestringFromWKB(Linestring(GeomFromText(astext(c.cab_loc)),GeomFromText(astext(a.address_loc)))))) AS distance
FROM cab c, address a
WHERE a.address = 'Foobar street 99'
ORDER BY distance ASC LIMIT 1;
解决方法:
SELECT c.cab_driver,
Round(glength(LinestringFromWKB(Linestring(GeomFromText(astext(c.cab_loc)),
GeomFromText(astext(a.address_loc)))))) AS distance
FROM cab c, address a
WHERE a.address = 'Foobar street 99'
ORDER BY distance ASC LIMIT 1;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。