PHP json_encode() 在 while 循环中

PHP json_encode() in while loop(PHP json_encode() 在 while 循环中)
本文介绍了PHP json_encode() 在 while 循环中的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我试图在获取数据库结果的同时在 while 循环中使用 json_encode().这是我的代码:

I am trying to use json_encode() in a while loop while getting database results. Here is my code:

<?

$database = sqlite_open("thenew.db", 0999, $error);
if(!$database) die($error);

$query = "SELECT * FROM users";
$results = sqlite_query($database, $query);
if(!$results) die("Canot execute query");

while($row = sqlite_fetch_array($results)) {
  $data = $row['uid'] . " " . $row['username'] . " " . $row['xPos'] . " " . $row['yPos'];
}
echo json_encode(array("response"=>$data));

sqlite_close($database);

?>

这个输出是

{"response":"lastUserID lastUser lastXPos lastYPos"}

{"response":"lastUserID lastUser lastXPos lastYPos"}

我希望它是...

{"response":["1 Alex 10 12", "2 Fred 27 59", "3 Tom 47 19"]}

{"response":["1 Alex 10 12", "2 Fred 27 59", "3 Tom 47 19"]}

所以我希望 json_encode() 函数将所有用户放入数组而不是最后一个.我该怎么做?谢谢

So I want the json_encode() function to put ALL users into the array rather than the last one. How would I do this? Thanks

推荐答案

尝试:

<?

$database = sqlite_open("thenew.db", 0999, $error);
if(!$database) die($error);

$query = "SELECT * FROM users";
$results = sqlite_query($database, $query);
if(!$results) die("Canot execute query");

$data = array();

while($row = sqlite_fetch_array($results)) {
  $data[] = $row['uid'] . " " . $row['username'] . " " . $row['xPos'] . " " . $row['yPos'];
}
echo json_encode(array("response"=>$data));

sqlite_close($database);

?>

这篇关于PHP json_encode() 在 while 循环中的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Why can#39;t I update data in an array with foreach loop?(为什么我不能用 foreach 循环更新数组中的数据?)
Foreach for arrays inside of an array(Foreach 用于数组内的数组)
PHP array get next key/value in foreach()(PHP 数组在 foreach() 中获取下一个键/值)
Using preg_match on a multidimensional array to return key values arrays(在多维数组上使用 preg_match 返回键值数组)
php foreach as key, every two number as a group(php foreach 为key,每两个数字为一组)
Treat a PHP class that implements Iterator as an array(将实现 Iterator 的 PHP 类视为数组)