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注入的正常警告将在这里应用.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...