php循环语句中显示的问题
我是初学者,正尝试写一个程序:下面的语句中,我想显示正在被处理的id号但是如果数据库有一百条信息那么(echo"当前ID".$id;)就会存在一百次而我想问的时,如何只让...
我是初学者,正尝试写一个程序:
下面的语句中,我想显示正在被处理的id号
但是如果数据库有一百条信息
那么
(echo "当前ID".$id;)
就会存在一百次
而我想问的时,如何只让程序显示当前正在循环的一次,而循环到下次时,就自动跳到下个呢?
而不是100次都一直累加着显示呢?
<?php
$sql="select * from tablett order by id desc";
$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo "当前ID".$id;
}
?>
正在要写WEB应用
但是,如果要执行一万次呢?
这一万次的循环读取数据库,取数据做对比再处理后,这样循环完一万次,已经要很久了
是不是可以有什么方法,可以每执行完一次,就告诉用户,已经执行完了一次呢
然后再执行第二次的时候,再告诉用户,但同时不显示第一次显示的内容,只显示第二次显示的内容呢??? 展开
下面的语句中,我想显示正在被处理的id号
但是如果数据库有一百条信息
那么
(echo "当前ID".$id;)
就会存在一百次
而我想问的时,如何只让程序显示当前正在循环的一次,而循环到下次时,就自动跳到下个呢?
而不是100次都一直累加着显示呢?
<?php
$sql="select * from tablett order by id desc";
$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo "当前ID".$id;
}
?>
正在要写WEB应用
但是,如果要执行一万次呢?
这一万次的循环读取数据库,取数据做对比再处理后,这样循环完一万次,已经要很久了
是不是可以有什么方法,可以每执行完一次,就告诉用户,已经执行完了一次呢
然后再执行第二次的时候,再告诉用户,但同时不显示第一次显示的内容,只显示第二次显示的内容呢??? 展开
2个回答
展开全部
事实上肯定是输出100次,你是想输出内容的时候删除上次显示的内容,如果你的程序是在控制太执行,一般的方法是回车不换行,也就是程序如下书写:
<?php
$sql="select * from tablett order by id desc";
$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo "\r当前ID".$id;
}
?>
这样每次显示的内容都在一行上,人们就只能看见最后一次。
如果你是在写WEB应用,实际上就没有这个必要,因为一般情况下WEB会有缓存,会在你的程序运行完毕之后才发给浏览器显示,也就是你在100次循环的过程中,浏览器上其实什么也不显示,状态栏显示“正在打开网页...”
补充:
在WEB里面循环一万次,这个每次提示也是浪费服务器CPU、客户端CPU、网络资源的,完全是哗众取宠的东西,正确的方法是估计大概要等待多久,在调用页面提示用户耐心等待。
如果你一定要每行提示,可以使用下面的方法:
首先是必须关闭PHP输出的缓存,然后每次输出的内容使用JS来更新,例如:
<?php
echo '正在处理的ID:<span id=div_id></span>';//显示容器
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo "<script type=text/javascript>div_id.innerHTML='$id';</script>"; //用JS代码更新容器显示
flush();//刷新显示
}
?>
<?php
$sql="select * from tablett order by id desc";
$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo "\r当前ID".$id;
}
?>
这样每次显示的内容都在一行上,人们就只能看见最后一次。
如果你是在写WEB应用,实际上就没有这个必要,因为一般情况下WEB会有缓存,会在你的程序运行完毕之后才发给浏览器显示,也就是你在100次循环的过程中,浏览器上其实什么也不显示,状态栏显示“正在打开网页...”
补充:
在WEB里面循环一万次,这个每次提示也是浪费服务器CPU、客户端CPU、网络资源的,完全是哗众取宠的东西,正确的方法是估计大概要等待多久,在调用页面提示用户耐心等待。
如果你一定要每行提示,可以使用下面的方法:
首先是必须关闭PHP输出的缓存,然后每次输出的内容使用JS来更新,例如:
<?php
echo '正在处理的ID:<span id=div_id></span>';//显示容器
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo "<script type=text/javascript>div_id.innerHTML='$id';</script>"; //用JS代码更新容器显示
flush();//刷新显示
}
?>
展开全部
事实上肯定是输出100次,你是想输出内容的时候删除上次显示的内容,如果你的程序是在控制太执行,一般的方法是回车不换行,也就是程序如下书写:
<?php
$sql="select
*
from
tablett
order
by
id
desc";
$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo
"\r当前ID".$id;
}
?>
这样每次显示的内容都在一行上,人们就只能看见最后一次。
如果你是在写WEB应用,实际上就没有这个必要,因为一般情况下WEB会有缓存,会在你的程序运行完毕之后才发给浏览器显示,也就是你在100次循环的过程中,浏览器上其实什么也不显示,状态栏显示“正在打开网页...”
补充:
在WEB里面循环一万次,这个每次提示也是浪费服务器CPU、客户端CPU、网络资源的,完全是哗众取宠的东西,正确的方法是估计大概要等待多久,在调用页面提示用户耐心等待。
如果你一定要每行提示,可以使用下面的方法:
首先是必须关闭PHP输出的缓存,然后每次输出的内容使用JS来更新,例如:
<?php
echo
'正在处理的ID:<span
id=div_id></span>';//显示容器
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo
"<script
type=text/javascript>div_id.innerHTML='$id';</script>";
//用JS代码更新容器显示
flush();//刷新显示
}
?>
<?php
$sql="select
*
from
tablett
order
by
id
desc";
$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo
"\r当前ID".$id;
}
?>
这样每次显示的内容都在一行上,人们就只能看见最后一次。
如果你是在写WEB应用,实际上就没有这个必要,因为一般情况下WEB会有缓存,会在你的程序运行完毕之后才发给浏览器显示,也就是你在100次循环的过程中,浏览器上其实什么也不显示,状态栏显示“正在打开网页...”
补充:
在WEB里面循环一万次,这个每次提示也是浪费服务器CPU、客户端CPU、网络资源的,完全是哗众取宠的东西,正确的方法是估计大概要等待多久,在调用页面提示用户耐心等待。
如果你一定要每行提示,可以使用下面的方法:
首先是必须关闭PHP输出的缓存,然后每次输出的内容使用JS来更新,例如:
<?php
echo
'正在处理的ID:<span
id=div_id></span>';//显示容器
while($row=mysql_fetch_array($query)){
$id=$row[id];
echo
"<script
type=text/javascript>div_id.innerHTML='$id';</script>";
//用JS代码更新容器显示
flush();//刷新显示
}
?>
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询