Home >Backend Development >PHP Tutorial >请问这个可以循环吗?

请问这个可以循环吗?

WBOY
WBOYOriginal
2016-06-23 13:46:19871browse

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)){
  }
}


嗯,我会继续努力的,感谢斑竹大大
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn