PHP Web服务:从MySQL获取多个记录并将其编码为JSON数组

时间:2018-10-10 19:01:53

标签: php mysql json web-services

我是使用MySQL的PHP​​ Web服务的新手。我遵循this教程。我使用phpmyadmin创建了一个表-> loan_applications。 Currenlty我在与id 1相关的表中有3条记录。我想检索所有3条记录,并希望将其编码为json。

我尝试了多种方法并尝试了谷歌搜索,但无法获得适当的json数组作为响应。这是我的get_applications_list.php

<?php

require_once 'include/DB_Functions.php';
$db = new DB_Functions();

// json response array
$response = array();

if (isset($_GET['id'])) {

    // receiving the post params
    $id = $_GET['id'];

    $applications = $db -> getApplicationsList($id);
    if ($applications) {
        // got applications successfully
        $response["status"] = 0;
        $response["id"] = $applications["id"];
        $response["application_id"] = $applications["application_id"];
        $response["requested_amount"] = $applications["requested_amount"];
        $response["interest_per_day"] = $applications["interest_per_day"];  
        $response["gst"] = $applications["gst"];    
        $response["tenure"] = $applications["tenure"];  
        $response["processing_fees"] = $applications["processing_fees"];    
        $response["amount_user_get"] = $applications["amount_user_get"];
        $response["amount_user_pay"] = $applications["amount_user_pay"];
        $response["application_latitude"] = $applications["application_latitude"];
        $response["application_longitude"] = $applications["application_longitude"];
        $response["application_status"] = $applications["application_status"];      
        $response["created_at"] = $applications["created_at"];  
        $response["updated_at"] = $applications["updated_at"];          
        $response["message"] = "Applications details fetched successfully";

        echo json_encode($response);
    } else {
        // applications failed to store
        $response["status"] = 1;
        $response["message"] = "Unknown error occurred in getting details!";
        echo json_encode($response);
    }       
} else {
    // receiving the post params
    $response["status"] = 2;
    $response["message"] = "Required parameters is missing!";
    echo json_encode($response);
}
?>  

这是我的DB_Functions.php

<?php

class DB_Functions {

private $conn;

// constructor
function __construct() {
    require_once 'DB_Connect.php';
    // connecting to database
    $db = new Db_Connect();
    $this->conn = $db->connect();
}

// destructor
function __destruct() {

}     
public function getApplicationsList($id){
    $stmt = $this->conn->prepare("SELECT * FROM loan_applications WHERE id = ?");
    $stmt->bind_param("s", $id);
    $stmt->execute();
    $applications = $stmt->get_result()->fetch_assoc();
    $stmt->close();

    if($applications){
        return $applications;
    }else {
        return false;
    }
}
}
?>   

这是我得到的答复:

{"status":0,"id":1,"application_id":1,"requested_amount":5000,"interest_per_day":"0.50","gst":18,"tenure":28,"processing_fees":"5.00","amount_user_get":4705,"amount_user_pay":5700,"application_latitude":"9.999999999","application_longitude":"9.999999999","application_status":1,"created_at":"2018-10-10 21:45:17","updated_at":"0000-00-00 00:00:00","message":"Applications details fetched successfully"}  

我仅获得一条记录,但我需要与ID 1相关联的所有3条记录。我尝试了很多但无法获得。

1 个答案:

答案 0 :(得分:0)

这里有很多问题

1-尽管不确定,但Currenlty I have 3 records in table related to id 1似乎是不正确的陈述。如果id是主键,则您不能针对一个id

记录3条记录

2-{{​​1}}总是返回一行,要获取多行或多行集合,您需要像下面这样

$stmt->get_result()->fetch_assoc();

3-从以下代码中可以很清楚地看到,您实际上只向后发送了一行

if ($result = $mysqli->query($query)) {

    /* fetch associative array */
    while ($row = $result->fetch_assoc()) {
        printf ("%s (%s)\n", $row["Name"], $row["CountryCode"]);
    }

    /* free result set */
    $result->free();
}

您应该这样做

if ($applications) {
        // got applications successfully
        $response["status"] = 0;
        $response["id"] = $applications["id"];
        $response["application_id"] = $applications["application_id"];
        $response["requested_amount"] = $applications["requested_amount"];
        $response["interest_per_day"] = $applications["interest_per_day"];  
        $response["gst"] = $applications["gst"];    
        $response["tenure"] = $applications["tenure"];  
        $response["processing_fees"] = $applications["processing_fees"];    
        $response["amount_user_get"] = $applications["amount_user_get"];
        $response["amount_user_pay"] = $applications["amount_user_pay"];
        $response["application_latitude"] = $applications["application_latitude"];
        $response["application_longitude"] = $applications["application_longitude"];
        $response["application_status"] = $applications["application_status"];      
        $response["created_at"] = $applications["created_at"];  
        $response["updated_at"] = $applications["updated_at"];          
        $response["message"] = "Applications details fetched successfully";

        echo json_encode($response);
    }