質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

6342閲覧

PHP,MySQLの値をJSONで出力することが出来ない

oyatsu8

総合スコア97

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2017/09/10 07:14

編集2017/09/10 11:30

サイト、入門書籍( PHP 7+MySQL 入門ノート 2016/7/1 大重 美幸 (著)の13章)、前回の質問回答などを参考に、MySQLの値をJSONで出力しようとしたのですが、
ブラウザに表示されるのは、

データベースtestに接続しました。
{"queryString":"SELECT * FROM test01"}

のようになるだけで、
自分の理解では、全てのデータがJSON形式で出力されると思ったのですが、
なぜかデータが表示されません。
echo($result);
などもためしてみたのですが、何も出力されませんでした、、
ご助言頂けたら幸いです。

PHP

1<?php 2function es($str) { 3 return htmlspecialchars($str, ENT_QUOTES, 'UTF-8'); 4} 5//エラー出力強制 6ini_set( 'display_errors', 1 ); 7//すべてのエラー表示 8error_reporting( E_ALL ); 9 10//データベースへの接続 11define('DB_NAME', 'test'); 12define('DB_HOST', 'test'); 13define('DB_USER', 'test'); 14define('DB_PASS', 'test'); 15 16$dbName = DB_NAME; 17 18$dsn = 'mysql:dbname=' . DB_NAME . ';host=' . DB_HOST . ';charset=utf8'; 19$option = array( 20 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, 21 PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, 22 PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => true, 23 PDO::ATTR_EMULATE_PREPARES => false, 24 PDO::ATTR_STRINGIFY_FETCHES => false 25); 26?> 27 28<!DOCTYPE html> 29<html lang="ja"> 30<head> 31<meta charset="utf-8"> 32<title>レコードを取り出す(すべて)</title> 33<link href="css/style.css" rel="stylesheet"> 34<!-- テーブル用のスタイルシート --> 35<link href="css/tablestyle.css" rel="stylesheet"> 36</head> 37<body> 38<div> 39 <?php 40 //MySQLデータベースに接続する 41 try { 42 $db = new PDO($dsn, DB_USER, DB_PASS, $option); 43 44 echo "データベース{$dbName}に接続しました。", "<br>"; 45 // SQL文を作る(全レコード) 46 $sql = "SELECT * FROM test01"; 47 48 $result = $db->query($sql); 49 50 //json 51 $json = json_encode($result); 52 echo($json); 53 }catch (Exception $e) { 54 echo '<span class="error">エラーがありました。</span><br>'; 55 echo $e->getMessage(); 56 exit(); 57 } 58 ?> 59</div> 60</body> 61</html> 62

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

$json = json_encode($result->fetchAll());
でイイ気がする。
PDOStatement::fetchAll

追記
回答がちょっと雑だったんで追記します。

*確認しておきたい知識
・PDO::query を実施すると、PDOStatement オブジェクトを返します。
・json_encode() は、resource 型以外の任意の型を JSON 形式にした文字列として返します。

今回のケースでは、json_encode() に PDOStatement をそのまま入れているため、PDOStatement のプロパティ(queryString)が表示されています。
本来期待するのは「結果セット」を json_encode したいので、「結果セット」を渡して上げる必要があります。
PDOStatement から全ての結果行を含む配列をとりだすには、PDOStatement::fetchAll が用意されているので、最初の回答のように記述すると、「結果セット」の配列を json_encode することが出来ます。

結果セットとして渡す配列は、PDOフェッチパターン大全のように、PDO::FETCH_* 定数 を PDOStatement::fetchAll に与えることで、容易に調整できるので、必要であれば、そちらを使って加工すると良いです。

投稿2017/09/10 13:05

編集2017/09/11 00:21
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

oyatsu8

2017/09/10 16:07

ありがとうございます!こちらも試してみた所うまくできました!
oyatsu8

2017/09/11 06:09

詳しい解説をありがとうございます。PDOStatement オブジェクト、resource 型、PDOStatement::fetchAll など まだよくわかっていなかったので、教えて頂いたキーワードを調べてみてようやく何となく理解出来ました。 改めてちゃんと勉強しないと、、と思いました。 ありがとうございました!!
guest

0

ベストアンサー

PDO::FETCH_ASSOCquery()メソッドの引数に追加してループすればOKだと思います。PHPマニュアルにはPDO Statementオブジェクト | FALSEが戻り値と書いてありますので、データはループして取得するのが普通だと思います。

実際に何が帰ってきているのか確認したい時はvar_dump()print_r()などで出力表示して確認します。

php

1 // SQL文を作る(全レコード) 2 $sql = "SELECT * FROM test01"; 3 $res = $db->query($sql, PDO::FETCH_ASSOC); 4 $res = $res !== false ? $res : []; 5 6 $result = []; 7 8 foreach($res as $row) { 9 $result[] = $row; 10 } 11 12 //json 13 $json = json_encode($result);

投稿2017/09/10 09:16

Tomak

総合スコア1652

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

oyatsu8

2017/09/10 10:47

ありがとうございました!出来ました! 実は PDO::FETCH_ASSOCが何なのかいまいちよくわかっていないので、 調べてみようと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問