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); 展开
$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); 展开
4个回答
展开全部
我来回答:
$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);
$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);
展开全部
$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 是把结果集中的当前行返回,行指针下移到下一行。只返回一行。你当然得到的是 一条数据的数组
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 是把结果集中的当前行返回,行指针下移到下一行。只返回一行。你当然得到的是 一条数据的数组
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
请用while循环逐条取出即可。
你只自行一次fetch array就只取出一条。
你只自行一次fetch array就只取出一条。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
$list=mysql_fetch_array($res);
是需要便利才能有全部结果的
是需要便利才能有全部结果的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询