ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

SQL-查找查询中特定行的位置

2019-10-24 16:29:39  阅读:151  来源: 互联网

标签:sql php


我正在使用论坛系统.我试图让用户看到他们发表的帖子.为了使此链接正常工作,我需要跳到他们所张贴的特定主题的页面,其中包含他们的帖子,因此书签可以正常工作,等等.由于这是旧论坛的新功能,我d希望对其进行编码,以便论坛系统不必跟踪每个帖子,而可以简单地自动填充此列表.

我知道如何填充列表,但是我需要这样做:

给定一个查询,查询中的X行(由标识符的组合保证是唯一的)将出现在哪里?像这样,我必须偏移多少行才能到达它?这将在排序查询中.

理想情况下,我想使用SQL而不是PHP来做到这一点,但是如果不能用SQL做到这一点,我想那也是答案. ^ _ ^

谢谢

解决方法:

嗯,这个解决方案有一些假设,但如果我正确理解,我认为它应该可以满足您的需求:

SELECT count(post_id) FROM posts
  WHERE thread_id = '{$thread_id}' AND date_posted <= '{$date_posted}'

这将使您获得特定线程中的行数(我假设您已经预先计算),该行数等于或早于发布日期(有问题的特定用户发布).

根据此信息(例如该线程的第15条帖子),您可以根据论坛的分页值来计算结果将基于哪个页面.即

// dig around forum code for number of items per page
$itemsPerPage = 10; // let's say
$ourCount = getQueryResultFromAbove(); 

// this is the page that post will be on
$page = ceil($ourCount / $itemsPerPage);

// for example
$link = '/thread.php?thread_id='.$thread_id.'&page='.$page;

标签:sql,php
来源: https://codeday.me/bug/20191024/1921995.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有