while($str=mysql_fetch_row($value)){
echo
$str[1]
}
这样就可以循环打印出来了,php里有个指针的概念
外部,比如$value中的值只有一个,是一维数组
那么不用写while,直接
$str=mysql_fetch_row($value)
echo
$str[1]
二维数组,用while相当于指针一直向下
恩,我根据我的理解去回答了你的问题,我也不是php骨灰,只能尽自己可能给你回答了
while循环和foreach循环在mysql_fetch_array()的用法:while举例如下:
<?php
mysql_connect("localhost", "mysql_user", "mysql_password") or
die("Could not connect: " . mysql_error())
mysql_select_db("mydb")
$result = mysql_query("SELECT id, name FROM mytable")
while ($row = mysql_fetch_array($result, MYSQL_NUM)) {
printf ("ID: %s Name: %s", $row[0], $row[1])
}
mysql_free_result($result)
?>
foreach循环举例如下:
$rows = mysql_fetch_all($result)
foreach($rows as $row){
printf ("ID: %s Name: %s", $rows[0], $rows[1])
}
*** 作数据库是最费性能的,(和 *** 作PHP相比), 没有数据库 *** 作 *** 作php可以很快循环完成6w次这个相当于是高并发的模拟 这6w条数据相当于 同时插入,而且你把 表结构改简单一些 就1个字段的话,print出的数据 还会比653多一些
说明你的数据库再插入到653的时候 受不住了,循环到653 卡住了,这和数据库的锁机制也有关系.
你可以打开看一眼你机器上的cup 以及内存 看看执行的时候是不是 突然上升.
如果不是你可以做个mysql 集群就能同时插入多条数据了.(服务器是不会653条就成这样).
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)