Home > Article > Backend Development > 为什么这个一下把数组的内容全部的打印出来了?
数据库里面有两个用户名 我写的这个查询后为什么一下子全都插入到数组里面去了 我打印$arr[0]一下都出来了 我就是想把查出来的两条数据分别插入到数组中 我这个应该怎么改呢?
<?php$pdo=new PDO("mysql:host=localhost;dbname=t1","root","");$stmt=$pdo->prepare("select * from user");$stmt->execute();$res=$stmt->fetchall(PDO::FETCH_ASSOC);foreach($res as $v){ $arr=array(); $arr[]=$v['username']; echo $arr[0];}?>
贴出结果!!
foreach($res as $v){
$arr=array(); //每次循环都初始化数组的话
$arr[]=$v['username']; //每次数组只会有一个元素
echo $arr[0]; //打印出数组唯一一个元素
}
调整如下:
$arr=array();
foreach($res as $v){
$arr[]=$v['username'];
}
print_r($arr);
试试看吧
贴出结果!!
foreach($res as $v){
$arr=array(); //每次循环都初始化数组的话
$arr[]=$v['username']; //每次数组只会有一个元素
echo $arr[0]; //打印出数组唯一一个元素
}
调整如下:
$arr=array();
foreach($res as $v){
$arr[]=$v['username'];
}
print_r($arr);
试试看吧
foreach($res as $v){
$arr=array(); //每次循环都初始化数组的话
$arr[]=$v['username']; //每次数组只会有一个元素
echo $arr[0]; //打印出数组唯一一个元素
}
调整如下:
$arr=array();
foreach($res as $v){
$arr[]=$v['username'];
}
print_r($arr);
试试看吧
foreach($res as $v){
$arr=array(); //每次循环都初始化数组的话
$arr[]=$v['username']; //每次数组只会有一个元素
echo $arr[0]; //打印出数组唯一一个元素
}
调整如下:
$arr=array();
foreach($res as $v){
$arr[]=$v['username'];
}
print_r($arr);
试试看吧
解决办法是将$arr=array();设定在foreach的外面,然后在外面设个$k=0,在foreach里面是$arr[$k]=$v['username']; ,然后在foreach里的结尾将$k++
$arr=array();
$k=0;
foreach($res as $v){
$arr[$k]=$v['username'];
$k++;
}
print_r($arr);
解决办法是将$arr=array();设定在foreach的外面,然后在外面设个$k=0,在foreach里面是$arr[$k]=$v['username']; ,然后在foreach里的结尾将$k++
$arr=array();
$k=0;
foreach($res as $v){
$arr[$k]=$v['username'];
$k++;
}
print_r($arr);