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

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

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

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

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

Q&A

解決済

2回答

401閲覧

sql文の読み方について

beginner_39

総合スコア77

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

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

0グッド

0クリップ

投稿2017/11/30 04:11

下記文の読み方(どんな意味なのか)を教えていただきたいです。
※mampでデータベースを勉強中で、テスト環境で動かしています。
※参考書を見ながら勉強しておりますが、中々理解ができずにいます。。。

① $user = "hogeroot"; ② $pass = "passroot";   try{ ③ $dbh = new PDO('mysql:host=localhost;dbname=db1;charset=utf8',$user,$pass); ④ $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); ⑤ $sql = "SELECT * FROM recipes"; ⑥ $stmt = $dbh->query($sql); ⑦ $result = $stmt->fetchAll(PDO::FETCH_ASSOC); ⑧ print_r($result); ⑨ $dbh = null;   } catch (Exception $e) { echo "エラー発生: " . htmlspecialchars($e->getMessage(), ENT_QUOTES, 'UTF-8') . "<br>"; die();   }

④から⑨までの意味がいまいちピンときません。
⑤についてはrecipesのデータを全て取る。ということはわかりましたが、
残りの部分が読めません。

また、try{}catch{}のcatchの構文についてもなぜこのような書き方になるの?
と思っております。

大変恐縮ですが読み方を教えていただきたいです。
よろしくお願いいたします。

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

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

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

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

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

num79kill

2017/11/30 11:36

最近 PHPとMySQL使っているから PHPMYADMINのタグをつけてる人が多いがあなたの質問でも不要です。
beginner_39

2017/12/04 23:44

ご指摘ありがとうございます。
guest

回答2

0

④から⑨までの意味がいまいちピンときません。

順番に
(4)エラーがあったときにcatchに処理を流す設定
(5)recipesテーブルの全データを抽出する設定データ
(6)(5)のSQL文を実行
(7)結果を$resultという変数に配列として受けています
なお、結果自体はASSOCが指定されているのでSQLで抽出した項目名がキーになっています
(8)$resultを試しに表示しているもので、主にデバグのさいにつかう書式です
(9)PDOのインスタンス$dbhをクリアしてます

また、try{}catch{}のcatchの構文についてもなぜこのような書き方になるの?

と思っております。

処理に失敗したらcatchに処理をとばすといういわゆる例外処理です
たとえばSQLの文法エラーなどはその結果を得るために提示のような書式を使用します

投稿2017/11/30 04:40

yambejp

総合スコア114769

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

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

0

ベストアンサー

まず題名が間違っているかと思います。
書いてらっしゃるのはSQLの文ではなく、見た限り、PHPでPDOを使用してDB接続をする為のコードですね。

さて上記悩んでいらっしゃることについてですが、過去に非常に素晴らしい記事を書いてくださっている方がおり、下記を読めばほぼ解決するかと思うので是非じっくり読んでみてください。
PHPでデータベースに接続するときのまとめ

try catchについては、例外が起きることが予想される処理をtryの後の{}で囲み、例外が発生した際はcatchの後の{}を実行するという意味の構文です。catchの後の()内はどの例外が起きた場合に処理するかというもので、上記の場合はExceptionなので全ての例外をキャッチするようになっています。
例外にも色んな種類があるので、どんな種類の例外がPHPにはあるのかというところからなんとなく調べてみてください。

以上です。頑張って下さい。

投稿2017/11/30 04:46

編集2017/11/30 05:29
comcom_0905

総合スコア44

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問