[英]Php push user array into users array and loop through users and user data (properties)
我将一堆用户放入一个数据库表(名为“users”)中,每个用户的属性都存储在表的列中:id、username、first_name、last_name 等等。
当用户登录时,她/他的数据从数据库中检索并显示在一个 HTML 表格中; 为此,我创建了函数(在 functions.php 文件中):
function user_data() {
$users = array();
$func_num_args = func_num_args();
$func_get_args = func_get_args();
if ($func_num_args > 1) {
unset($func_get_args[0]);
$fields = '`' . implode( '`, `', $func_get_args) . '`';
}
$query = "SELECT $fields FROM users";
$result = query($query);
$col = mysqli_fetch_assoc($result);
array_push($users, $col);
print_r($users);
return $users;
}
然后在用户页面上:
$user_data = $user_data[0];
echo "<span>Welcome, " . $user_data['first_name'] . " " . $user_data['last_name'] . "!</span>";
数据库中有 2 个用户,但 $users 数组只包含一个用户,如 print_r($users) 所示:
Array
(
[0] => Array
(
[username] => ajax
[first_name] => Razvan
[last_name] => Zamfir
[email] => razvan.zamfir80@gmail.com
[telefon] => 0743127315
[oras] => Bucuresti
[adresa] => Strada Alexandru Ipsilanti nr. 6, bloc 29E, sc. B, et. 3, ap. 83.
)
);
我需要遍历所有用户和每个用户的属性以显示一个通用表,该表在每行上显示用户的名字、姓氏和“编辑”按钮。
我究竟做错了什么?
迭代查询指定的字段的行,然后使用fetch_assoc获取每个字段
function user_data() {
$users = array();
$func_num_args = func_num_args();
$func_get_args = func_get_args();
if ($func_num_args > 1) {
unset($func_get_args[0]);
$fields = '`' . implode( '`, `', $func_get_args) . '`';
}
//$result = query($query);
$conn = new mysqli("yourhost","username","pass", "dbname");
$query = "SELECT $fields FROM users";
$result=$conn->query($query);
if ($result->num_rows > 0) {
while ($row =$result->fetch_assoc()) {
array_push($users,$row);
}
/* free result set */
mysqli_free_result($result);
}
print_r($users);
return $users;
}
然后迭代从user_data()
方法返回的数组以提取值。
var $usr = user_data();
foreach ($usr as $arr){
foreach ($arr as $key => $value){
echo $key ." ".$value;
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.