是否可以将查询中的两个数字相乘,以便对MYSQL查询进行分页?
SELECT * FROM Posts
LIMIT $itemsPerPage
OFFSET ($pageNumber * $itemsPerPage)
当我试图在SQL中动态地将这两个数字相乘时,我在乘法部分得到了一个关于我的语法的错误。在查询中不能将数字相乘吗?
My complete query
SELECT com_id, time_stamp, comBy, post_id, comContent, IFNULL(likes, 0) - IFNULL(dislikes, 0) AS likeResult, profile_pic FROM Comments C
# Adding Likes
LEFT JOIN (SELECT likedCom_id, COUNT(*) AS likes FROM Comment_Likes
GROUP BY likedCom_id) Cl ON C.com_id=Cl.likedCom_id
LEFT JOIN (SELECT dislikedCom_id, IFNULL(COUNT(*),0) AS dislikes FROM Comment_Dislikes
GROUP BY dislikedCom_id) Cd ON C.com_id=Cd.dislikedCom_id
LEFT JOIN (SELECT user_id, profile_pic FROM Users) U
ON U.user_id = C.comBy
WHERE post_id = '10'
ORDER BY time_stamp DESC
LIMIT 5
OFFSET (0 * 5)
例如,上面的OFFSET (0 * 1)
代码分别表示pageNumber和itemsPerPage变量。
我在HeidiSQL上得到关于我的查询的错误:
发布于 2019-06-11 02:36:26
您需要限制,并且不能使用传递限制或偏移量的计算(您可以使用动态SQL)。
在select语法中,偏移量是LIMIT子句中的一个子句(请参见https://dev.mysql.com/doc/refman/8.0/en/select.html#id4651990):
[LIMIT {[offset,] row_count | row_count OFFSET offset}]
my_value = pageNumber * itemsPerPage;
'SELECT * FROM Posts
LIMIT 100 OFFSET ' + my_value
并且您应该使用order by
'SELECT *
FROM Posts
ORDER BY your_col
LIMIT 100 OFFSET ' + my_value
发布于 2019-06-11 02:56:53
OFFSET
参数是标量值,请提供数字文本或单个绑定值。
如果我们需要做乘法,我们可以在客户端做,并将结果作为单个参数提供给OFFSET
。
看起来代码是动态生成SQL语句的。我们可以这样做:
$sql = "SELECT ... OFFSET " . (int)($pageNumber * $itemsPerPage) ;
或
$offset = $pageNumber * $itemsPerPage ;
$sql = "SELECT ... OFFSET " . (int)$offset ;
https://stackoverflow.com/questions/56531772
复制相似问题