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

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

ただいまの
回答率

90.48%

  • PHP

    20912questions

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

  • MySQL

    6038questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

複数レコードのアップデートについて

解決済

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 521

tetsuyuka

score 1

<?php

print "<pre>";
print_r($_POST);
print "</pre>";

//formから受け取り
//Array
//(
//    [checkall] => on
//    [uid] => Array
//        (
//            [0] => 21
//            [1] => 20
//            [2] => 19
//        )
//
//    [ucheck] => Array
//        (
//            [0] => OK
//            [1] => OK
//            [2] => OK
//        )
//
//    [update] => 更新
//)

try {
  $db = new PDO('mysql:host=localhost;dbname=project;charset=utf8', 'phpusr', 'phppass');
  if (isset($_POST['update'])) {
    $stt = $db->prepare('UPDATE project SET ucheck=:ucheck WHERE uid=:uid');
    $stt->bindValue(':ucheck', $_POST['ucheck']);
    $stt->bindValue(':uid', $_POST['uid']);
    $stt->execute();
  }
} catch(PDOException $e) {
  die('エラーメッセージ:'.$e->getMessage());
}

//DBのログ
//Query    UPDATE project SET ucheck='Array' WHERE uid='Array'

PHP初心者でmysqlの複数レコードの更新の方法が分からないので
お手数ですが教えてください。

formから[uid]と[ucheck]を受け取りupdate処理をしたいのですが
繰り返し構文を作ろうとしてもうまくいかない為お願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • Kosuke_Shibuya

    2016/05/19 16:02

    テーブルの定義がわからないと答えようがありません。定義を提示してください。

    キャンセル

回答 3

checkベストアンサー

+2

 Before
try { 
  $db = new PDO('mysql:host=localhost;dbname=project;charset=utf8', 'phpusr', 'phppass'); 
  if (isset($_POST['update'])) { 
    $stt = $db->prepare('UPDATE project SET ucheck=:ucheck WHERE uid=:uid'); 
    $stt->bindValue(':ucheck', $_POST['ucheck']); 
    $stt->bindValue(':uid', $_POST['uid']); 
    $stt->execute(); 
  } 
} catch(PDOException $e) { 
  die('エラーメッセージ:'.$e->getMessage()); 
}
 After
// デバッグコード
// 開発中は常にコレを記述することをお勧めします。
error_reporting(E_ALL);
ini_set('display_errors', 1);

try { 
  $db = new PDO('mysql:host=localhost;dbname=project;charset=utf8', 'phpusr', 'phppass'); 

  // 他の箇所で特に設定していない場合、これを実行しないとエラー発生時に例外が投げられない
  $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

  if (isset($_POST['update'])) { 
    $stt = $db->prepare('UPDATE project SET ucheck=:ucheck WHERE uid=:uid'); 

    for (int $i = 0; $i < count($_POST['uid']); $i++) {
      $stt->bindValue(':ucheck', $_POST['ucheck'][$i]); 
      $stt->bindValue(':uid', $_POST['uid'][$i]); 
      $stt->execute(); 
    }
  } 
} catch(PDOException $e) { 
  die('エラーメッセージ:'.$e->getMessage()); 
}


ちなみに、本当はリクエストパラメータをサニタイズせずプログラム内で使用するのはよろしくありません。
$stt->bindValue(':ucheck', $_POST['ucheck'][$i]); などの部分のこと)
http://www.weblio.jp/content/%E3%82%B5%E3%83%8B%E3%82%BF%E3%82%A4%E3%82%BA

その対策については、以下などを参考にまずはご自分で考えてみてください。
http://php.net/manual/ja/function.filter-input.php
http://php.net/manual/ja/function.filter-input-array.php

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

try {
  $db = new PDO('mysql:host=localhost;dbname=project;charset=utf8', 'phpusr', 'phppass');
  $stt = $db->prepare('UPDATE project SET ucheck=:ucheck WHERE uid=:uid');

  if (isset($_POST['update'])) {
    foreach ($_POST as $i => $data) {
        $stt->bindValue(':ucheck', $data['ucheck'][$i]);
        $stt->bindValue(':uid', $data['uid'][$i]);
        $stt->execute();
    }
  }

} catch(PDOException $e) {
  die('エラーメッセージ:'.$e->getMessage());
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

教えて頂いてありがとう御座います。
回答頂いたもので希望通りの動作が確認出来ました。セキュリティ対策もこれから覚えていきます。

まだ1年も経たない若輩者ではありますがこれからもお願いします。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

関連した質問

  • 解決済

    画面遷移なしで編集したいのですが、書き方が全くわかりません。。

    「編集」と「削除」を画面遷移なしで実行したいのですが、ajaxが分からず困っています。どうすれば、意図した結果が得られるでしょうか?>< PHPとMySQLを使っています。 PH

  • 解決済

    チェックボックスのデータベース登録について

    チェックボックスにチェックされた数によって、動的にデータベースに反映させたいのですが、行き詰まっています。。現状、以下のコードです。$checkboxにはチェックボックス(配列が入

  • 解決済

    mysqlでUPDATAが実行されません

    エラーは何も無いかのように見受けられるのですが データベースを見ると更新されていませんでした 以下がそのソースです sqlで更新する関数です アドバイスよろしくお願いします

  • 解決済

    MySQL 複数行のUPDATE

    formから配列を用いてPOSTされたデータを受け取って、UPDATEしたいのですが、、 配列を受け取るとこまではなんとかなりましたが、そこからのコードがよくわかっておりません。

  • 解決済

    MySQLでUPDATEが実行できない

    前提・実現したいこと PHPとMySQLで記事を「投稿」「編集」「削除」するシステムを作っています。   投稿と削除は完成したのですが、UPDATE文で実装しようと思っている編

  • 解決済

    ベースのデータを検索後、表示されたデータリストをさらに詳細検索するには?

    データベースのデータを検索後、表示されたデータリストからさらに詳細検索するにはどうしたらよいでしょうか? 下記の流れで検索を考えています。 ①入力フォームにキーワードを

  • 解決済

    複数の変数のupdateについて

    各店舗(id)のリーダー(leaders)に、なる(value=2)ならない(value=3)をupdateしたいのですが以下のコードを実行してもカラムの値が変わることはありません

  • 受付中

    postされた値で絞込みしたいのですがエラーが出ました

     前提・実現したいこと postされた値から絞込みをしたいと考えています  発生している問題・エラーメッセージ mampで一通り完成したものを実際にサーバー(スターフリーサーバ

同じタグがついた質問を見る

  • PHP

    20912questions

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

  • MySQL

    6038questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。