热搜:NVER node 开发 php

请问这个可以循环吗?

2024-08-18 17:00:01
请问这个可以循环吗?

while(!!$_rerows = mysql_fetch_array($_show_repost,MYSQL_ASSOC)){

         循环语句1

          while(!!$_rerows = mysql_fetch_array($_show_repost,MYSQL_ASSOC)){
                         循环语句2
           }
}

假设单个循环语句1要执行x次,单个循环语句2要执行y次
请问执行过程是不是先执行循环语句1一次,然后进入循环语句2进行循环直至结束,然后再回到循环语句1的循环体,再接着执行循环语句1,然后再次进入循环语句2的循环进行循环直至结束,大家能懂我意思吗?循环语句2总共执行了x*y次
我不知道是不是写错了,实际效果是循环语句2的整个循环过程只循环了y次


回复讨论(解决方案)

mysql_fetch_array() 函数从结果集中取得一行作为关联数组,或数字数组,或二者兼有
返回根据从结果集取得的行生成的数组,如果没有更多行则返回 false。
可是重新进入第二个while不是会重新执行mysql_fetch_array() 吗?

二重循环的算法时间复杂度为 O(n*n) 
即内层循环体将执行 n(外层)* n(内层)次

不过你的嵌套循环是多余的,因为你都是对同一资源($_show_repost)进行循环
所以外层会执行一次,内层会执行n-1次

while(!!$_rerows = mysql_fetch_array($_show_repost,MYSQL_ASSOC)){

         循环语句1

          while(!!$_rerows = mysql_fetch_array($_show_rerepost,MYSQL_ASSOC)){
                         循环语句2
           }
}

不好意思各位楼上代码写错了,是查询2个不同的

二重循环的算法时间复杂度为 O(n*n) 
即内层循环体将执行 n(外层)* n(内层)次

不过你的嵌套循环是多余的,因为你都是对同一资源($_show_repost)进行循环
所以外层会执行一次,内层会执行n-1次


不好意思之前写错了,里面那个查询的是另外一个

那么内层的 $_show_rerepost 需要重新查询或回绕

那么内层的 $_show_rerepost 需要重新查询或回绕


版主那是不是这样循环就不能实现?有什么实现的好方法吗

我都不知道你打算做什么?能有什么好方法

就是我在数据库建了2个表,一个是回帖信息,一个是对回帖的回复,循环语句1就是先一个一个输出回帖,循环语句2(里面有if语句判定)就是假如在这个回帖有对回帖的回复,就输出对回帖的回复内容,我想实现的效果是输出一条回帖,底下如果有别人回复这个回帖就显示回复,然后循环输出下个回帖,就和百度贴吧回复功能类似

表一 回帖信息
表二 回帖的回复
所以表二中必有一字段指向表一的id,假设为 fid
于是有

$_show_repost = mysql_query('select * from 表一');
where($_rerows = mysql_fetch_array($_show_repost,MYSQL_ASSOC)) {
  $_show_rerepost = mysql_query("select * from 表二 where 表二.fid=$_rerows[id]");
  while(!!$_rerows = mysql_fetch_array($_show_rerepost,MYSQL_ASSOC)){
  }
}

表一 回帖信息
表二 回帖的回复
所以表二中必有一字段指向表一的id,假设为 fid
于是有

$_show_repost = mysql_query('select * from 表一');
where($_rerows = mysql_fetch_array($_show_repost,MYSQL_ASSOC)) {
  $_show_rerepost = mysql_query("select * from 表二 where 表二.fid=$_rerows[id]");
  while(!!$_rerows = mysql_fetch_array($_show_rerepost,MYSQL_ASSOC)){
  }
}


嗯,我会继续努力的,感谢斑竹大大