PHP查询MYSQL数据表,返回的ARRAY是一条数据的

返回的$list是一条数据的数组,而不是多条数据的二维数组,为什么?谁帮帮。谢谢,数据库里有多条数据$link=mysql_connect("localhost","ro... 返回的$list是一条数据的数组,而不是多条数据的二维数组,为什么?谁帮帮。谢谢,数据库里有多条数据

$link=mysql_connect("localhost","root","root");
mysql_query("set names gbk");
$msql="select * from pic";
$res=mysql_db_query("text",$msql,$link);
echo $res;
$list=mysql_fetch_array($res);
print_r($list);

mysql_close($link);
展开
 我来答
cmoooo
2010-05-28 · TA获得超过3587个赞
知道小有建树答主
回答量:741
采纳率:0%
帮助的人:665万
展开全部
我来回答:

$list=mysql_fetch_array($res);这句话执行的是$msql="select * from pic";这条数据库语句。而却只能执行一条,这一条语句也有其执行规律,就是数据库列表中的第一行。

可是却有一个例外,也是一个规矩,$list=mysql_fetch_array($res);这条语句执行第一次取出第一行,接着执行第二次取出第二行。依此类推。

这就,就产生了一种比较简单却又可行的取出方案:

使用while循环(例程如下):

$link=mysql_connect("localhost","root","root");
mysql_query("set names gbk");
$msql="select * from pic";
$res=mysql_db_query("text",$msql,$link);

//你的程序在这里开始改变:

$i=0;
$list_arr=array();
while($list=mysql_fetch_array($res)){//这一句,就是判断是否还有数据没有取完,如果取完,会由数据库返回false,停止while循环,如果有,则继续;
$list_arr[$i]=$list;
$i++;
}
print_r($list_arr);//到了这里,当while循环结束,你要取出的所有数据的二维数组也就形成了。具体有多长,有多少个数组元素,就看你的数据库中有多少行数据了。

mysql_close($link);
百度网友0f37e23c0
推荐于2016-08-26 · TA获得超过1543个赞
知道大有可为答主
回答量:1070
采纳率:50%
帮助的人:1290万
展开全部
$link=mysql_connect("localhost","root","root");
mysql_query("set names gbk");
$msql="select * from pic";
$res=mysql_db_query("text",$msql,$link);
echo $res;
while ( $list=mysql_fetch_array($res))
print_r($list);
//因为 mysql_fetch_array 是把结果集中的当前行返回,行指针下移到下一行。只返回一行。你当然得到的是 一条数据的数组
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友69975fa
2010-05-28 · TA获得超过669个赞
知道小有建树答主
回答量:1523
采纳率:0%
帮助的人:903万
展开全部
请用while循环逐条取出即可。
你只自行一次fetch array就只取出一条。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
quanwei0924
2010-05-28 · 超过21用户采纳过TA的回答
知道答主
回答量:148
采纳率:0%
帮助的人:90.5万
展开全部
$list=mysql_fetch_array($res);
是需要便利才能有全部结果的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式