微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQL计数使用LIMIT时的总行数

我正在尝试创建一个简单的图像库,每页显示16个图像.我正在使用LIMIT 16在页面显示正确的数量,但是如果有超过16行,我想在底部链接,允许用户导航到下一页.

我知道我可以通过删除限制并简单地使用循环来显示前16个项目来实现所需的结果,但这将是低效的.显然,COUNTING行总是= 16.

$sql .= "posts p,images im,postimages pi WHERE
    i.active = 1 
    AND pi.post_id = p.id
    AND pi.image_id = im.image_id 
    ORDER BY created_at LIMIT 16";

任何人都可以提出更有效的方法吗?

谢谢

解决方法

除了要获取所有其他人提到的计数的单独查询之外,您还需要偏移给定页面的结果.
$sql .= "posts p,postimages pi WHERE
    i.active = 1 
    AND pi.post_id = p.id
    AND pi.image_id = im.image_id 
    ORDER BY created_at 
    LIMIT ". ($page - 1) * $pagesize .",". $pagesize;

关于sql注入的正常警告将在这里应用.

原文地址:https://www.jb51.cc/mssql/81592.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐