以JSON格式返回MySQL数据

时间:2016-10-14 21:42:07

标签: php mysql json

在使用JSON / PHP时我是新手。我一直试图根据这个答案让这个工作。

How to generate .json file with PHP?

我正在尝试查询MySQL数据库以JSON格式输出它而不将其写入新文件。 file.json因为我正在提取动态数据。我可以创建一个创建json数组的脚本,但是我需要JSON格式的输出。我在下面的示例链接中使用的脚本连接到数据库但是,它没有填充数据。它只是给了我这个输出。我添加了数据库连接检查以检查脚本是否连接到数据库。

成功连接{"流媒体":[]}

这是我目前正在使用的代码。有没有人可以告诉我我缺少什么,可以改进。出于安全原因删除了DB信息。

<?php

header('Content-type:application/json;charset=utf-8');

//Make connection to database
$db=new PDO('mysql:dbname=streamdb;host=localhost;','root','');  

// Check connection
if ($db->connect_error) {
    die("Connection failed: " . $db->connect_error);
} 
echo "Connected successfully";

//Prepare the query for analyzing    
$sql=$db->prepare('select * from maintable'); 

$response = array();
$streamers = array();
$result=mysql_query($sql);
while($sql=mysql_fetch_array($result)) 
{ 
$displayname=$row['DisplayName']; 
$streamkey=$row['StreamKey']; 

$streamers[] = array('DisplayName'=> $displayname, 'StreamKey'=> $streamkey);

} 

$response['streamers'] = $streamers;

echo stripslashes(json_encode($response));

?>

-Thanks!

3 个答案:

答案 0 :(得分:2)

首先,仅使用PDO。没有mysql_ *函数。

然后你的代码应该是这样的:

$pdo = new PDO('mysql:host=...', 'username', 'password', [
        PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
    ]);
$result = $pdo->query('SELECT DisplayName, StreamKey FROM ...');
$rows = $result->fetchAll(PDO::FETCH_ASSOC);
header('Content-Type: application/json;charset=utf-8');
echo json_encode(['streamers' => $rows],
        JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_NUMERIC_CHECK);

PDO::ERRMODE_EXCEPTION将PDO设置为将所有错误作为异常抛出,因此可以以简单一致的方式处理它们。

PDO::FETCH_ASSOC设置fetchAll()将行返回为数组,其中列名用作数组键。

json_encode()将负责生成有效的JSON输出。由于您没有将JSON嵌入到HTML中,因此不需要转义斜杠,我们将使其更好地缩进以便于调试。

答案 1 :(得分:0)

正如我在评论中所说,问题可能是&#34; $ row&#34;未初始化。应该是:

while($row=mysql_fetch_array($result))

此外,您使用了与PDO不兼容的mysql_函数。您应该使用$db->query

来处理您的请求

当你提出建议时,我可能会给你一个技巧。

我认为只需检索一个基本上是查询结果内容的表(在$ result中)就有很多代码。我猜你几乎每个请求都有类似的代码。所以我的一般做法是构建一个名为extractResult的通用函数,它直接从查询结果中生成一行数组。

这是功能:

/**
* Extract a php array from the result of a db query.
* This result can be directly parsed in JSON for instance.
*/
function extractResult($res) {
    $arr = array();
    while($line = $res->fetch()) {
        $count = count($line)/2;
        for ($i=0; $i<$count; $i++) {
            unset($line[$i]);
        }
        array_push($arr, $line);
    }
    return $arr;
}

注意:for循环使用&#34;取消设置&#34;用于删除带数字的条目。抓取返回的是:

Array("DisplayName" => "Loulou", 0 =>"Loulou", "StreamKey" => 12, 1 => 12)

因此它删除了数字副本。

所以你可以像这样使用它,你的代码变得更轻:

<?php

header('Content-type:application/json;charset=utf-8');

//Make connection to database
$db=new PDO('mysql:dbname=streamdb;host=localhost;','root','');  

// Check connection
if ($db->connect_error) {
    die("Connection failed: " . $db->connect_error);
} 
echo "Connected successfully";

$result=$db->query('select display_name AS DisplayName, stream_key AS StreamKey from maintable');

$response = array();
$response['streamers'] = extractResult($result);

echo json_encode($response);

?>

请注意,您必须在请求中直接指定所需的列名称! :)

不知道它是否有趣,但我总是使用这个技巧,因此从DB构建JSON变得更加容易和轻松。祝你好运。

答案 2 :(得分:0)

您可以在这里查看工作代码

<?php
$con=mysqli_connect($servername,$username,$password,$databasename);
if (mysqli_connect_errno())
{
echo "Connection Error" . mysqli_connect_error();
}
$query = "SELECT * FROM TableName";
$result = mysqli_query($con,$query);
$querydata = array();
while($data = mysqli_fetch_array($result)) {
$querydata[] = $data;
}
echo json_encode($querydata);
mysqli_close($con);
?>