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

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

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

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

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

Q&A

解決済

1回答

2623閲覧

①前の画面で送ったデータが初期値として入っている状態にしたい、②SQLのUPDATEを実行したい

study_m

総合スコア24

PHP

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

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

0グッド

0クリップ

投稿2017/04/14 08:10

編集2017/04/27 03:14

###前提・実現したいこと
XAMPPとMySQLを使ってショッピングサイトを作っています。

①前の画面で送ったデータを$_GETで受け取り、初期値に送ったデータが入っている状態にしたいです。
ブラウザ上でソースを確認すると、下記のようにvalueの値が空になっていました。↓
<input type="text" name="name" style="width:200px" value="">

②SQLのUPDATEを実行したい。前回の質問と同様に、既存のデータを修正したいです。

###ボタン押下後のアクション指定画面「pro_branch.php」

<?php //■「参照」が選択されているとき if(isset($_POST['disp'])==true){ if(isset($_POST['procode'])==false){ header('Location:pro_ng.php'); exit(); } $pro_code=$_POST['procode']; header('Location:pro_disp.php?procode='.$pro_code); exit(); } //■「追加」が選択されているとき if(isset($_POST['add'])==true){ header('Location:pro_add.php'); } //■「編集」が選択されているとき if(isset($_POST['edit'])==true){ if(isset($_POST['procode'])==false){ header('Location:pro_ng.php'); exit(); } $staff_code=$_POST['procode']; header('Location:pro_edit.php?procode='.$pro_code); exit(); //print "修正ボタンが押された"; } //■「削除」が選択されているとき if(isset($_POST['delete'])==true){ if(isset($_POST['procode'])==false){ header('Location:pro_ng.php'); exit(); } $staff_code=$_POST['procode']; header('Location:pro_delete.php?procode='.$pro_code); exit(); //print "削除ボタンが押された"; } ?>

###データ修正画面「pro_edit.php」

<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> <title>ろくまる農園</title> </head> <body> <?php try{ $pro_code =$_GET['procode']; //■DBにSQL文で命令する $dsn ='mysql:dbname=shop;host=localhost;charset=utf8'; $user ='root'; $password=''; $dbh =new PDO($dsn ,$user ,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); //codeレコードのmst_proテーブルからnameカラムを選んで$sqlに代入する $sql ='SELECT name,price FROM mst_product WHERE code=?'; //■$stmtから全て取り出す(fetch~)ための準備をする $stmt =$dbh->prepare($sql); //取り出すデータを$pro_codeに絞る $data[]=$pro_code; //■execute($data)でSQLで命令を出す $stmt->execute($data); //■$stmtから全て取り出す $rec =$stmt->fetch(PDO::FETCH_ASSOC); //商品名を変数にコピー $pro_name=$rec['name']; $pro_price=$rec['price']; //■DBとのアクセスを切断する $dbh=null; //データベースがダウンしているときに動くプログラム }catch(Exception $e){ print "ただいま障害によりサーバーに接続できません。大変ご迷惑をおかけしています。"; exit(); } ?> <!--■ここからHTML--> 商品修正<br /><br /> 商品コード<br /> <?php print $pro_code; ?> <br /><br /> <form method="post" action="pro_edit_check.php"> <!-- hiddenで受け取る。--> <input type="hidden" name="code" value="<?php print $pro_code; ?>"> 商品名<br /> <input type="text" name="name" style="width:200px" value="<?php print $pro_name; ?>"><br /> 価格<br /> <input type="text" name="price" style="width:50px" value="<?php print $pro_price; ?>">円<br /><br /> <input type="button" onclick="history.back()" value="戻る"> <input type="submit" value="OK"> </form> </body> </html>

###情報修正実行画面「pro_edit_done.php」
UPDATEが実行されません。
バインドするパラメータの順番は正しいと思います。

<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> <title>ろくまる農園</title> </head> <body> <?php try{ //■データベースが正常に動いているときに動く本来のプログラム $pro_code=$_POST['code']; $pro_name=$_POST['name']; $pro_price=$_POST['price']; $pro_code=htmlspecialchars($pro_code); $pro_name=htmlspecialchars($pro_name); $pro_price=htmlspecialchars($pro_price); //■DBにSQL文で命令する $dsn ='mysql:dbname=shop;host=localhost;charset=utf8'; $user ='root'; $password=''; $dbh =new PDO($dsn ,$user ,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $sql ='UPDATE mst_product SET name=?,price=? WHERE code=?'; //■$stmtに$sqlを準備する $stmt =$dbh->prepare($sql); $data[]=$pro_name; $data[]=$pro_price; $data[]=$pro_code; //■execure($data)でSQLで命令を出す $stmt->execute($data); //DBとのアクセスを切断する $dbh=null; print '修正しました<br/><br/>'; //データベースがダウンしているときに動くプログラム }catch(Exception $e){ print "ただいま障害によりサーバーに接続できません。大変ご迷惑をおかけしています。"; //強制終了 exit(); } ?> <a href="pro_list.php">戻る</a> </body> </html>

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

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

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

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

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

guest

回答1

0

ベストアンサー

//■「編集」が選択されているとき if(isset($_POST['edit'])==true){ if(isset($_POST['procode'])==false){ header('Location:pro_ng.php'); exit(); } $staff_code=$_POST['procode']; header('Location:pro_edit.php?procode='.$pro_code); exit(); //print "修正ボタンが押された"; } ``` の部分において、

$staff_code=$_POST['procode'];

ではなくて、

$pro_code=$_POST['procode'];

とすれば全て一発で治りそうな気がするのですが、いかがでしょうか?初期値が入らないのもUPDATEされないのも、ここが原因かと思われます。変数のコピペミスですかね^^。

投稿2017/04/14 17:21

編集2017/04/14 17:25
SaintKnowledge

総合スコア368

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

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

study_m

2017/04/17 01:22

コピペミスですね・・・気が付かなかったです(^^; おっしゃる通りで、変更したらすべて一発で治りました!!助かりました!ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問