将这两个查询组合在一起的正确语法是什么?
SELECT clicks FROM clicksTable WHERE clicks > 199 ORDER BY clicks ASC LIMIT 1和
SELECT clicks FROM clicksTable ORDER BY clicks DESC LIMIT 1我试过:
SELECT clicks FROM clicksTable WHERE clicks > 199 ORDER BY clicks ASC LIMIT 1
UNION
SELECT clicks FROM clicksTable ORDER BY clicks DESC LIMIT 1;但我得到了“不正确的使用联合和订购的”。
另外,编辑,我希望结果在一行中返回。这样我就可以访问php中的值了。
$row['nextclick'] and $row['topclick'] 根据Simon的建议,我不应该使用UNION,因为我想返回一行数据
发布于 2013-01-11 15:49:50
您不能在您的第一个ORDER BY,然后UNION它。
编辑
不过,你可以
对单个SELECT应用ORDER或place,将子句放在括住SELECT的括号内:
就像在MySQL UNION documentation一样
(SELECT a FROM t1 WHERE a=10 AND B=1 ORDER BY a LIMIT 10)
UNION
(SELECT a FROM t2 WHERE a=11 AND B=2 ORDER BY a LIMIT 10);,这将使您的SQL
(SELECT clicks FROM clicksTable WHERE clicks > 199 ORDER BY clicks ASC LIMIT 1)
UNION
(SELECT clicks FROM clicksTable ORDER BY clicks DESC LIMIT 1);编辑2
返回array
SELECT (SELECT clicks
FROM clicksTable
WHERE clicks > 199
ORDER BY clicks ASC
LIMIT 1) AS NextClick,
(SELECT clicks
FROM clicksTable
ORDER BY clicks DESC
LIMIT 1) AS TopClick;https://stackoverflow.com/questions/14281663
复制相似问题