首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >可以使用带乘法的偏移量对查询进行分页吗?

可以使用带乘法的偏移量对查询进行分页吗?
EN

Stack Overflow用户
提问于 2019-06-11 02:33:26
回答 2查看 219关注 0票数 1

是否可以将查询中的两个数字相乘,以便对MYSQL查询进行分页?

代码语言:javascript
复制
SELECT * FROM Posts
LIMIT $itemsPerPage
OFFSET ($pageNumber * $itemsPerPage)

当我试图在SQL中动态地将这两个数字相乘时,我在乘法部分得到了一个关于我的语法的错误。在查询中不能将数字相乘吗?

My complete query

代码语言:javascript
复制
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上得到关于我的查询的错误:

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 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}]

代码语言:javascript
复制
my_value  = pageNumber * itemsPerPage; 

'SELECT * FROM Posts
LIMIT 100 OFFSET ' + my_value 

并且您应该使用order by

代码语言:javascript
复制
'SELECT * 
FROM Posts
ORDER BY your_col
LIMIT 100 OFFSET ' + my_value 
票数 1
EN

Stack Overflow用户

发布于 2019-06-11 02:56:53

OFFSET参数是标量值,请提供数字文本或单个绑定值。

如果我们需要做乘法,我们可以在客户端做,并将结果作为单个参数提供给OFFSET

看起来代码是动态生成SQL语句的。我们可以这样做:

代码语言:javascript
复制
$sql =  "SELECT ... OFFSET " . (int)($pageNumber * $itemsPerPage) ;

代码语言:javascript
复制
$offset = $pageNumber * $itemsPerPage ;
$sql =  "SELECT ... OFFSET " . (int)$offset ;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56531772

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档