###前提・実現したいこと
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>
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/04/17 01:22