求救:关于这段代码中取数据的问题!!

php初学者1 2013-06-14 12:41:42
向各位求救
$sql="select * from xym_pic";
$res=mysql_query($sql,$conn);
while ($row=mysql_fetch_assoc($res)){
$data[]=$row;
}// 随机抽取9条记录以模拟实际情况
$keys = array_rand($data, 10);
$json = array();
foreach($keys as $key){
$json[] = $data[$key];
}
echo json_encode( $json );
这段代码中瀑布流data.php部分的代码,每次获取一次,就从数据库里面取出数据 放到数组$data[]里面,原来的是随机去取9条记录,我想让这段编程,每次获取去除按时间排序的9条记录,就是第一次取出来的是0-9,第二次是10-9,以此类推!那位能帮忙告诉怎么取出数据呢?万分感谢啊!小弟奉上100分,解决了另加!!!如果好心人原意加QQ指导,那是相当的感激啊:QQ 2 7 7 6 2 8 1 8 1
...全文
210 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
php初学者1 2013-06-14
  • 打赏
  • 举报
回复
引用 12 楼 xuzuning 的回复:
取完了就注销掉 session 或设置 $_SESSION 为空 js 那边当然也需要是否有数据返回,没有的话就不再发请求
十分感谢啊,我把JS搞一下试试! 感谢您的耐心帮助哦!!!!!!!
xuzuning 2013-06-14
  • 打赏
  • 举报
回复
取完了就注销掉 session 或设置 $_SESSION 为空 js 那边当然也需要是否有数据返回,没有的话就不再发请求
php初学者1 2013-06-14
  • 打赏
  • 举报
回复
引用 10 楼 xuzuning 的回复:
你究竟想要做什么?
就是这个瀑布流,我想按条取出来最新的80条数据,然后就终止了,我刷新页面,再重新取数据! 现在这个瀑布流的机制是,静态页面调用js,js控制页面当前位置,距离底部多少个px之后获取php文件,这段php代码没问题,就是js获取的时候,是不是得判断一下如果json为空就不在获取呢? 现在是js只要滚动就会不断的获取内容,如果php里面结果集为空,他在获取一次也就会有数据了!
xuzuning 2013-06-14
  • 打赏
  • 举报
回复
你究竟想要做什么?
php初学者1 2013-06-14
  • 打赏
  • 举报
回复
引用 7 楼 XiaoShengbboy 的回复:
[quote=引用 6 楼 XiaoShengbboy 的回复:] [quote=引用 5 楼 xuzuning 的回复:] 取不到了就从头再取
现在就是因为取不到了,我判断如果结果集是空的话就销毁session,刷新页面还是取不出来数据[/quote] 结果集为空的话 我让session销毁了,但是他又会无限循环了 我想结果集为空了,就不取结果了,直到页面刷新,才重新计数 请问怎么解决呢[/quote] 这个 代码最后的结果集 json是返回给一个JS文件的,js判断页面位置不停的加载新内容,我即使销毁了session,一加载也会重新开始获取数据! 这个很是头疼啊!
xuzuning 2013-06-14
  • 打赏
  • 举报
回复
session_start();
if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;
$last = $_SESSION['last'];
 
$sql="select * from xym_pic limit $last,9";
$res=mysql_query($sql,$conn);
if(mysql_num_rows($res) ==0) {
  $last = $_SESSION['last'] = 0;
  $sql="select * from xym_pic limit $last,9";
  $res=mysql_query($sql,$conn);
}

while ($row=mysql_fetch_assoc($res)){
  $data[]=$row;
}
$_SESSION['last'] += count($data);
echo json_encode( $data )
php初学者1 2013-06-14
  • 打赏
  • 举报
回复
引用 6 楼 XiaoShengbboy 的回复:
[quote=引用 5 楼 xuzuning 的回复:] 取不到了就从头再取
现在就是因为取不到了,我判断如果结果集是空的话就销毁session,刷新页面还是取不出来数据[/quote] 结果集为空的话 我让session销毁了,但是他又会无限循环了 我想结果集为空了,就不取结果了,直到页面刷新,才重新计数 请问怎么解决呢
php初学者1 2013-06-14
  • 打赏
  • 举报
回复
引用 5 楼 xuzuning 的回复:
取不到了就从头再取
现在就是因为取不到了,我判断如果结果集是空的话就销毁session,刷新页面还是取不出来数据
xuzuning 2013-06-14
  • 打赏
  • 举报
回复
取不到了就从头再取
ywq0127 2013-06-14
  • 打赏
  • 举报
回复
引用 3 楼 XiaoShengbboy 的回复:
[quote=引用 1 楼 xuzuning 的回复:]
session_start();
if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;
$last = $_SESSION['last'];

$sql="select * from xym_pic limit $last,9";
$res=mysql_query($sql,$conn);
while ($row=mysql_fetch_assoc($res)){
  $data[]=$row;
}
$_SESSION['last'] += count($data);
echo json_encode( $data )
;
我还有一个小问题,就是我数据库里面一共有 80多条记录,每次取出来九条,取出来8次,就取完了,但是我刷新页面的时候session还在,我就取不出来数据了,请问怎么解决一下呢?谢谢啊[/quote] 瀑布流应该也不会用session存放吧?应该是和分页一样通过请求参数确定数据起始吧
php初学者1 2013-06-14
  • 打赏
  • 举报
回复
引用 1 楼 xuzuning 的回复:
session_start();
if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;
$last = $_SESSION['last'];

$sql="select * from xym_pic limit $last,9";
$res=mysql_query($sql,$conn);
while ($row=mysql_fetch_assoc($res)){
  $data[]=$row;
}
$_SESSION['last'] += count($data);
echo json_encode( $data )
;
我还有一个小问题,就是我数据库里面一共有 80多条记录,每次取出来九条,取出来8次,就取完了,但是我刷新页面的时候session还在,我就取不出来数据了,请问怎么解决一下呢?谢谢啊
php初学者1 2013-06-14
  • 打赏
  • 举报
回复
感谢版主的回复 已经解决了 谢谢谢谢!!!!!!!!!
xuzuning 2013-06-14
  • 打赏
  • 举报
回复
session_start();
if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;
$last = $_SESSION['last'];

$sql="select * from xym_pic limit $last,9";
$res=mysql_query($sql,$conn);
while ($row=mysql_fetch_assoc($res)){
  $data[]=$row;
}
$_SESSION['last'] += count($data);
echo json_encode( $data )
;

21,893

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧