如果在mysql表当中使用的geometry格式的字段是分开的,不是直接写的geometry字段,怎么可以把相应的数据查询出来呢?求解答,急


如何像这样sql语句进行适配呢?或者有更好地方法

如果在mysql表当中使用的geometry格式的字段是分开的,不是直接写的geometry字段,怎么可以把相应的数据查询出来呢?求解答,急



“Devil组”引证GPT后的撰写:
下面是一个示例查询,假设有一个表格叫做 locations,其中包含 latitude 和 longitude 字段:
SELECT ST_AsText(ST_Point(latitude, longitude)) AS location FROM locations;
在这个查询中,我们使用 ST_Point() 函数将 latitude 和 longitude 字段组合成一个点,并使用 ST_AsText() 函数将其转换为文本格式。
例如,假设要查询位于矩形范围内的所有位置:
SELECT * FROM locations WHERE ST_Contains(ST_MakeEnvelope(min_longitude, min_latitude, max_longitude, max_latitude, 4326), ST_Point(latitude, longitude));
在这个查询中,我们使用 ST_MakeEnvelope() 函数创建一个矩形范围,并使用 ST_Contains() 函数来判断每个位置是否在这个范围内。请注意,4326 是一个 EPSG 代码,表示 WGS84 坐标系。
需要注意的是,MySQL 必须启用空间扩展功能,这可以通过安装和启用适当的插件或扩展来实现。