热搜:NVER node 开发 php

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

2024-09-15 12:05:01
求救:关于这段代码中取数据的问题!!

本帖最后由 XiaoShengbboy 于 2013-06-14 00:42:16 编辑

向各位求救
$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

回复讨论(解决方案)

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 )
;

感谢版主的回复 已经解决了 谢谢谢谢!!!!!!!!!

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还在,我就取不出来数据了,请问怎么解决一下呢?谢谢啊


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还在,我就取不出来数据了,请问怎么解决一下呢?谢谢啊
瀑布流应该也不会用session存放吧?应该是和分页一样通过请求参数确定数据起始吧

取不到了就从头再取

取不到了就从头再取
现在就是因为取不到了,我判断如果结果集是空的话就销毁session,刷新页面还是取不出来数据


取不到了就从头再取
现在就是因为取不到了,我判断如果结果集是空的话就销毁session,刷新页面还是取不出来数据

结果集为空的话 我让session销毁了,但是他又会无限循环了
我想结果集为空了,就不取结果了,直到页面刷新,才重新计数
请问怎么解决呢

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 )



取不到了就从头再取
现在就是因为取不到了,我判断如果结果集是空的话就销毁session,刷新页面还是取不出来数据

结果集为空的话 我让session销毁了,但是他又会无限循环了
我想结果集为空了,就不取结果了,直到页面刷新,才重新计数
请问怎么解决呢
这个 代码最后的结果集 json是返回给一个JS文件的,js判断页面位置不停的加载新内容,我即使销毁了session,一加载也会重新开始获取数据!
这个很是头疼啊!

你究竟想要做什么?

你究竟想要做什么?
就是这个瀑布流,我想按条取出来最新的80条数据,然后就终止了,我刷新页面,再重新取数据!
现在这个瀑布流的机制是,静态页面调用js,js控制页面当前位置,距离底部多少个px之后获取php文件,这段php代码没问题,就是js获取的时候,是不是得判断一下如果json为空就不在获取呢?

现在是js只要滚动就会不断的获取内容,如果php里面结果集为空,他在获取一次也就会有数据了!

取完了就注销掉 session 或设置 $_SESSION 为空

js 那边当然也需要是否有数据返回,没有的话就不再发请求

取完了就注销掉 session 或设置 $_SESSION 为空

js 那边当然也需要是否有数据返回,没有的话就不再发请求

十分感谢啊,我把JS搞一下试试!
感谢您的耐心帮助哦!!!!!!!