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

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

ただいまの
回答率

89.52%

【PHP/SQLite3】外部PHPのSQL文実行結果を出力したい

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 1,842

nnahito

score 1839

 質問概要

ユーザがアクセスするindex.phpに、APIっぽくしたsql.phpの出力結果を表示させたい。

イメージ説明

しかし、以下の様なエラーが出て、解決策が見当たらない。

<b>Fatal error</b>:  Uncaught exception 'PDOException' with message 'SQLSTATE[HY000] [14] unable to open database file' in /Users/USERNAME/Sites/database/operation/sql.php:7
Stack trace:
#0 /Users/USERNAME/Sites/database/operation/slq.php(7): PDO-&gt;__construct('sqlite:../db/da...')
#1 /Users/USERNAME/Sites/database/index.php(20): require_once('/Users/USERNAME...')
#2 {main}
  thrown in <b>/Users/USERNAME/Sites/database/operation/sql.php</b> on line <b>7</b><br />

 環境

  • MacOSX Yosemite 10.10.5(14F1912)
  • PHP 5.5.36 (cli) (built: Jun 12 2016 23:47:46) 
  • Server version: Apache/2.4.16 (Unix) / Server built:   Jul 22 2015 21:03:09
  • Firefox 48.0.1

 質問詳細

ユーザがアクセスするページ(index.phpとします)と、
データベースからデータを取得し出力するAPIのようなPHP(sql.phpとします)を作りました。

そして、ユーザがindex.phpにアクセスした際に、
sql.phpから返されたデータベースのデータ(JSON形式)を、
riot.jsを使ってindex.phpに表示させたいと思っております。

イメージ説明

しかし、いざ実行してみると何も出力されておらず、
ブラウザの「ソースコードを見る」から出力ソースを見てみると、以下の様なエラーが表示されておりました。

<b>Fatal error</b>:  Uncaught exception 'PDOException' with message 'SQLSTATE[HY000] [14] unable to open database file' in /Users/USERNAME/Sites/database/operation/sql.php:7
Stack trace:
#0 /Users/USERNAME/Sites/database/operation/slq.php(7): PDO-&gt;__construct('sqlite:../db/da...')
#1 /Users/USERNAME/Sites/database/index.php(20): require_once('/Users/USERNAME...')
#2 {main}
  thrown in <b>/Users/USERNAME/Sites/database/operation/sql.php</b> on line <b>7</b><br />

エラー文で調べてみると、パーミッションに問題があると書かれているページが多く出てきます。

しかし、データベースファイルのあるフォルダのパーミッションは777、
データベースファイルのパーミッションは666でした。
とりあえず、データベースファイルのパーミッションを777にしてみましたが、エラーは消えません。

これは、どのように解消すればよろしいのでしょうか。
お知恵をお貸しください。

 Appendix

index.phpの、sql.phpを読みだす箇所(参考サイト様

<?php
ob_start();
include('./operation/sql.php');
$contents = ob_get_contents();
ob_end_clean();

echo "$contents";
?>

sql.php全文(一部省略)
なお、jQueryのajax通信や直接アクセスするとエラーなく出力されます。

<?php
// DB操作開始
$dbh = new PDO('sqlite:data.db');

// ゲームの評価をユーザの評価数で返す
$sth = $dbh->prepare("SQL文は省略");
$sth->execute();

// JSON形式に変換し、返していく
$count = 0;
$result = "[";
while( $row = $sth->fetch() ){
    $gameData = $dbh->prepare("SQL文は省略");
    $gameData->execute( array() );

    $gd = $gameData->fetch();

    // 配列をJSONに変換
    $json = json_encode($gd, JSON_UNESCAPED_UNICODE);

    // JSONをまとめる
    $result .= $json . ',';

    $count = $count + 1;


    if ( $count > 10 ){
        break;
    }

}

// 最後の余分な一文字を削除
$result = substr($result, 0, -1);

// JSONの終わり
$result .= "]";

// 出力
echo $result;


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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • JinwonKim

    2016/09/05 12:23

    sql.php 単体での動作確認は行いましたか?

    キャンセル

  • nnahito

    2016/09/05 12:33

    はい、質問文にも記載してあるとおりですが、、jQueryのajax通信や直接アクセスするとエラーなく出力されます。

    キャンセル

回答 1

check解決した方法

+3

お騒がせしました。
自己解決しました。

結論から言うと、includeの落とし穴に落ちていました。
includeを使うと、index.phpの階層から見て、データベースファイルのパスを指定しないといけないのですね。

sql.phpのPODを

// DB操作開始
$dbh = new PDO('sqlite:'.dirname(__FILE__).'/../db/data.db');


のように、指定し直すとエラーが消えました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 89.52%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる