0

我已成功从数据库中获取内容并以 JSON 格式输出结果。但我想添加一个在数据库中不存在的文本,我就卡在这里了。

$statement = $sql->prepare("SELECT data_filename,
                                   data_filetype,
                                   data_uniqid,
                                   data_description,
                                   data_coordinates,
                                   exif_taken,
                                   exif_camera,
                                   exif_camera_seo,
                                   exif_resolution,
                                   exif_sensitivity,
                                   exif_exposure,
                                   exif_aperture,
                                   exif_focallength,
                                   is_downloadable,
                                   is_notaccurate,
                                   allow_fullsize

                            FROM photos
                            WHERE data_filename = 'P1170976'");
$statement->execute();
$results = $statement->fetchAll(PDO::FETCH_ASSOC);

$json = json_encode($results);

echo $json;

那个代码给了我

[{"data_filename":"P1170976","data_filetype":"JPG","data_uniqid":"","data_description":"","data_coordinates":"","exif_taken":"0000-00-00","exif_camera":"","exif_camera_seo":"","exif_resolution":"","exif_sensitivity":"0","exif_exposure":"","exif_aperture":"","exif_focallength":"","is_downloadable":null,"is_notaccurate":null,"allow_fullsize":null}]

$json = json_encode...这当然是正确的,但如果我在I'm getting下添加这两条新行null

$newdata = array('test' => 'just testing');
$json[] = $newdata;

我在这里做错了什么?

4

2 回答 2

0

json_encode()返回一个字符串,因此不能将其作为数组处理,即向字符串添加元素。

如评论中所述,您需要在使用之前添加这些行json_encode()或将其解码回数组json_decode(),然后应用这些行,然后再返回json_encode()

json_encode和的用法示例json_decode

$array = array("this" => array("will" => array("be" => "json")));
$string = json_encode($array); // string(31) "{"this":{"will":{"be":"json"}}}"

// ...

$array2 = json_decode($string); // now it’s same array as in first $array
$array2["new"] = "element";
$string2 = json_encode($array2);
var_dump($string2); // string(46) "{"this":{"will":{"be":"json"}},"new":"string"}"
于 2013-06-06T21:58:40.997 回答
0

尝试这个:

$newdata = array('test' => 'justtesting');
$results[] = $newdata;
$json = json_encode($results);

或者如果您在编码后肯定需要它:

$json = json_encode($results);
//lots of stuff
$jarray = json_decode($results, true);
$newdata = array('test' => 'justtesting');
$jarray[] = $newdata;
$json = json_encode($jarray);
于 2013-06-06T22:02:31.143 回答