gpt4 book ai didi

php - MySql:查找 table2.name WHERE table1.lat = table2.lat AND table1.lng = table2.lng;

转载 作者:行者123 更新时间:2023-11-29 03:44:49 26 4
gpt4 key购买 nike

在过去的几天里,我一直在努力寻找这个问题的答案。我有一个 GPS 数据路线表。和一张积分表。我需要的是一个 MySql 语句,对于给定的路线,将告诉我两个端点的 Point.Name。我可以写 4 个单独的语句,但我相信有更好的方法。

这些表具有相似的列 {rowiduseridlatitudelongitude},使事情变得有趣:

Route.Name = '2011-06-27';

Point.Name = 'location_1';

要获得第一个和最后一个点很容易。 (在最后一点的 LIMIT 之前添加 DESC )

SELECT `rowid`, `latitude`, `longitude` FROM `$db`.`Route` 
WHERE `userid` LIKE '$userid' AND `name` = '$name' ORDER BY `rowid` LIMIT 1;

我一直在阅读有关 OUTER JOIN 的内容,并认为它会起作用,这与我得到的一样接近。

SELECT DISTINCT a.`rowid`, a.`latitude`, a.`longitude`, b.`name` 
FROM `$db`.`Route` a
RIGHT OUTER JOIN `$db`.`Point` b ON a.`latitude` = b.`latitude`
AND a.`longitude` = b.`longitude` WHERE a.`userid` LIKE '$userid'
AND a.`name` = '$name';

期望的输出:

rowid | latitude | longitude | name

'16660', '49.22551', '-122.57416', 'location_5'

'16792', '49.16722109', '-122.98667883', 'location_1'

实际输出:

rowid | latitude | longitude | name

'16791', '49.16721654', '-122.98723093', 'location_1'

'16792', '49.16722109', '-122.98667883', 'location_1'

我将非常感谢帮助我解决此问题的任何帮助。如果需要更多详细信息,请告诉我。

==== 编辑 ====

SELECT `name`, `latitude`, `longitude` FROM `$db`.`Point`
WHERE (`latitude`,`longitude`) IN(
SELECT `rowid`, `latitude`, `longitude` FROM
( SELECT `rowid`, `latitude`, `longitude` FROM `$db`.`Route`
WHERE `userid` LIKE '$userid' AND `name` = '$name' ORDER BY `rowid` LIMIT 1) as t1
UNION
( SELECT `rowid`, `latitude`, `longitude` FROM `$db`.`Route`
WHERE `userid` LIKE '$userid' AND `name` = '$name' ORDER BY `rowid` DESC LIMIT 1) )

问题是这会生成错误代码:1235 This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'

因此,我需要进行更多实验,以获取不使用 LIMIT 的结果或检索结果,然后使用结果生成第二个查询。我稍后会回复你。再次感谢。

最佳答案

您可以使用 UNION合并这两个 SQL。

SELECT `rowid`, `latitude`, `longitude` FROM 

( SELECT `rowid`, `latitude`, `longitude` FROM `$db`.`Route`
WHERE `userid` LIKE '$userid' AND `name` = '$name' ORDER BY `rowid` LIMIT 1) AS t0
UNION
( SELECT `rowid`, `latitude`, `longitude` FROM `$db`.`Route`
WHERE `userid` LIKE '$userid' AND `name` = '$name' ORDER BY `rowid` DESC LIMIT 1) AS t1

关于php - MySql:查找 table2.name WHERE table1.lat = table2.lat AND table1.lng = table2.lng;,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7591434/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com