データベース接続関係で「try{~catch~}」ってよく出てきますが、意味と使い方ってどんなものなんでしょうか
調べても参考になる情報が無くて困ってます
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/07/25 01:37
退会済みユーザー
2016/07/25 01:53
回答5件
0
ベストアンサー
やってみてダメならこうするというのがtry~catchの基本的な考え方
プログラムというのはすべての条件を想定して常に
エラーを発生させないように書くのがベターですが、
エラーを前提に例外処理をするという考え方もできます
そういう書き方をしておけばエラーが発生してもプログラムを
止めずに後ろにデータを流すことができます。
たとえばjavascriptでもこんなふうにかけます
javascript
1<script> 2try{ 3 throw a; 4}catch(e){ 5 document.write(e); 6} 7</script>
多くの上級言語で採用されている書き方です
追記
エラーは自分用に制御できます
PHP
1<?PHP 2set_error_handler('myErrorHandler'); 3function myErrorHandler($errno, $errstr, $errfile, $errline) 4{ 5 switch($errno) { 6 case E_NOTICE: 7 throw new exception("common notice:".$errstr."<br>"); 8 break; 9 case E_USER_NOTICE: 10 throw new exception("my notice:".$errstr."<br>"); 11 break; 12 default: 13 return false; 14 } 15 return true; 16} 17//(1) 予めerrorを想定して自分用のNOTICEを作成 18try{ 19 if(!isset($a)) trigger_error("no a!",E_USER_NOTICE); 20 print $a; 21 print 1/0; 22}catch(exception $e){ 23 print $e->getMessage(); 24} 25 26//(2) 発生したNOTICEを自分用のエラーメッセージを表示 27try{ 28 print $a; 29 print 1/0; 30}catch(exception $e){ 31 print $e->getMessage(); 32} 33 34//(3) NOTICEではないエラーはシステムに任せる 35try{ 36 print 1/0; 37}catch(exception $e){ 38 print $e->getMessage(); 39} 40//エラーにかかわらず後ろには流れている 41print "continue..."; 42?>
PDOなどでよく使われるのは、Exceptionを前提に例外処理が用意されているからです
ご自身でもなにかライブラリを作るときにはこのように例外を用意しておくと
プログラムを止めずにバグを発見できます。
投稿2016/07/25 01:35
編集2016/07/25 03:06総合スコア114784
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
投稿2016/07/25 01:02
総合スコア2037
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/07/25 01:12
2016/07/25 05:22 編集
0
try catchは設計思想です。
どういう時に使うかと言う事ではなく、どういう思考で使われるかを考えた方がわかりやすいと思います。
システムを設計するときに、例えばログインの機能の設計で
・メールアドレスとパスワードを入力させる
・メールアドレスとパスワードに一致する会員情報をDBから取得する
・セッションに会員情報を登録する
・DBから取得した会員名を画面に表示する
という設計記述はとても分かりやすいと思いますし、普通はそのような記述になっていると思います。
が、コレが以下のような記述だと、正しいとしてもとても分かりづらくなります。
・もしセッションに既にログイン情報があった場合、TOP画面へ遷移させる
・メールアドレスとパスワードを入力させる
・もしメールアドレスがメールアドレスの形式でなかった場合、メールアドレス不正のエラーを返答する
・もしパスワードが日本語だった場合、パスワード不正のエラーを表示する
・メールアドレスとパスワードに一致する会員情報をDBから取得する
・もしDBに接続できなかった場合、システムエラーを返答する
・もしDBからデータが取得できなかった場合、認証エラーを返答する
・もしDBから複数のデータが取得された場合、システムエラーを返答する
・もし・・・
プログラマー上がりのシステム設計の初心者によくある記述の仕方です。
これでは、その機能が何をする機能なのかわかりにくくなります。
設計時点だけでなく、実装時点でも同じ問題が起こり、if文が大量にあったりネストが繰り返されたプログラムは、可読性が低く、メンテナンスもしづらく、バグが発生しやすい危険なプログラムを生み出します。
このため、try内で「正常系」の動作を規定し、正常系から外れる処理分岐については異常系としてcatch内で処理する。
そういう設計思想をコードにそのまま反映する仕組みだと考えています。
投稿2016/07/25 03:16
総合スコア5405
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2016/07/25 04:47
0
例外処理構文のことです。
「例外処理」という意味がわからないのであれば、wikiとかで調べてください。
PHPの他にもJava,C++,Javascriptなどのプログラミング言語でも採用されています。
決して、「データベース接続に関するキーワードである」だけではありません。
データベース接続は他のプログラムを起動するので、よくわからないエラーが起きやすい。
⇒例外処理をしないと想定外の動きをする可能性があります。
PHPでのコーディングは、kaz.Suenagaさんが記載されているように公式を確認して、ご自身で確認してみてください。
公式の例1であれば
PHP
1function inverse($x) { 2 if (!$x) { 3 throw new Exception('ゼロによる除算。'); 4 } 5 return 1/$x; 6}
↓上記を以下のようにコメントアウトする
PHP
1function inverse($x) { 2// if (!$x) { 3// throw new Exception('ゼロによる除算。'); 4// } 5 return 1/$x; 6}
両方やってみてこの時どういう動きをするのかも確認してください。
以前にも記載しましたが、聞く前に「まずやってみよう」。
それでどこの動きが悪いのかを聞いた方がいいです。机上のみでの質問のように感じます。
プログラムがバグったとしても別に命とられるわけでもないし、アタマだけではなく体で覚えるのも習得への近道ですよ。
投稿2016/07/25 02:31
総合スコア254
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。