php mysql查询返回多行,将数据保存到对象

标签 php mysql sql row

我正在尝试从返回多行的 mysql 查询中提取数据。该代码当前编码为仅处理一行。 如何将多行数据保存到Date对象的实例变量中?

<?php
session_start();
require 'database.php';

class Date {
    private $id = '';
    private $titl = '';
    private $tim = '';
    private $dat = '';
    private $usern = '';

}

if ($_SESSION['loginstatus']!=1){
    die;
}

$username=$_SESSION['username'];
$date=$_POST['dateChosen'];

$stmt = $mysqli ->prepare("select ID, title, time from events where date=? and creator=?");    
if (!$stmt){
    $error = $mysqli->error;
    $string="Query Prep Failed:" . $error; 
    echo json_encode(array(
        "message"=> $string));
    exit;
}


$stmt -> bind_param('ss',$date,$username);
$stmt -> execute();
$stmt ->bind_result($ID, $title,$time);
$count = 0;
while ($stmt->fetch()){
    $count += 1;

    echo json_encode(array("id"=>$ID,
        "title"=> $title, "time"=>$time));
}
if ($count == 0){
    echo json_encode(array(
        "title"=> "NOT SET", "time"=>"NOT SET"));
}
$stmt->close();
header("Content-Type: application/json");
?>

最佳答案

您正在创建多个单独/独立的 JSON 字符串,这是不正确的。您需要在循环中构建一个数组,然后在循环完成后对该数组进行一次编码。

例如

$data = array();
while($stmt->fetch()) {
   $data[] = array('id' => $ID, 'title' => etc....);
}
echo json_encode($data);

现在你正在制作

{"id":1,"title":"foo",...}{"id":2,"title":"bar",...}{etc...}

这是一个语法错误。应该是

[{"id":1,"title":"foo",...},{"id":2,"title":"bar",...},{etc...}]

关于php mysql查询返回多行,将数据保存到对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31460538/

相关文章:

php - 生成从 10000000 到 99999999 的唯一随机数

php - 将数据传递给 Laravel 事件

MySQL 最低排序和分组依据

mysql - 我无法连接到 phpmyadmin

mysql - Node.js 访问 WampServer MySQL 数据库

C++ DB2 清除 QTEMP 中的非日志表

SQL Server NText 字段限制为 43,679 个字符?

php - 对于 PDO PHP,将值存储在 var 中安全吗?

javascript - PHP:strtotime 崇敬返回奇怪的日期?

mysql排序无模式字符串,末尾有数字