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

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

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

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

4回答

2804閲覧

配列データの受取について

Z-TALBO

総合スコア525

PHP

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

1グッド

0クリップ

投稿2016/02/19 02:58

編集2016/02/19 09:59

まず、データの送信側に関してのコードです。

HTML

1// DBからデータを受け取る 2while($row = $stmt->fetch()) { 3 $row = array( 4 "data" => array( 5 array( 6 "id" => $row['id'], 7 "name" => $row['name'], 8 "dakoku" => $row['dakoku']), 9 ) 10 ); 11 $row_ct = count($row['data']); 12 13 for($no = 0; $no < $row_ct; $no++) { 14?> 15<form action="update.php" method="post"> 16<tr> 17<td> <?= h($row['data'][$no]['name']); ?> </td> 18<td> <select name="data[<?= $no; ?>]['dakoku']" value="<?= h($row['data'][$no]['dakoku']; ?>"> 19<option <?= $row['data'][$no]['dakoku'] != '出勤' ?: 'selected' ?> value="出勤">出勤</option> 20<option <?= $row['data'][$no]['dakoku'] != '退勤' ?: 'selected' ?> value="退勤">退勤</option> 21<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休入">休入</option> 22<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休戻">休戻</option> 23</select> 24<td> 25<?php } ?> 26<?php } ?> 27</tr> 28<input type="submit" value="保存">

だいぶ省略したりとかありますが、、、、
上記のようなコードを作成し、表示させると、データベースに入っていたのが表示させることはできました。

例えばで、updata.phpにてprint_r($_POST)してみたのですが、最後の行の一行しかPOSTされていない様子です。

氏名:テスト 打刻:出勤 時:12 分:30
氏名:テスト 打刻:退勤 時:18 分:30
保存
と表示されたとして、保存をクリックしたら、
Array([data]=>Array([0]=>Array(['dakoku']=>退勤//あと省略)
だったのです。

解決法はどのようになるでしょうか?


【追記】
回答いただいた内容での修正です。
※回答いただいた内容のままではあります。

HTML

1// DBからデータを受け取る 2while($row = $stmt->fetch()) { 3 $row['data'][] = array( 4 array( 5 "id" => $row['id'], 6 "name" => $row['name'], 7 "dakoku" => $row['dakoku']), 8 ); 9 ** // whileの閉じタグをここに変更** 10 } 11 $row_ct = count($row['data']); 12 13 for($no = 0; $no < $row_ct; $no++) { 14?> 15<form action="update.php" method="post"> 16<tr> 17<td> <?= h($row['data'][$no]['name']); ?> </td> 18<td> <select name="data[<?= $no; ?>]['dakoku']" value="<?= h($row['data'][$no]['dakoku']; ?>"> 19<option <?= $row['data'][$no]['dakoku'] != '出勤' ?: 'selected' ?> value="出勤">出勤</option> 20<option <?= $row['data'][$no]['dakoku'] != '退勤' ?: 'selected' ?> value="退勤">退勤</option> 21<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休入">休入</option> 22<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休戻">休戻</option> 23</select> 24<td> 25<?php } ?> 26</tr> 27<input type="submit" value="保存">

上記のようにwhileの閉じタグを変更してみましたが、、、
そうなると、そもそもデータが表示されなくなりました。エラーは出ていません。

whileを閉じてしまったから?でしょうか?
質問時のコードであれば、値などは表示されます。


【追記】
最初の質問のコードでの話しですが、

PHP

1while($row = 2※省略させていただきます 3$row_ct = count($row['data']); 4の後に、var_dump($row); 5// array(1){["data"]=>array(1){[0]=>array(3){["id"]=>○○["name"]=>○○["dakoku"]=>○○}}} 6// array(1){["data"]=>array(1){[0]=>array(3){["id"]=>××["name"]=>××["dakoku"]=>××}}} 7となりました。 8var_dump($row_ct);だと 9int(1)int(1)となりました

※データが2行あった事としています。
こういう部分がもしかして原因なのか?ということも考えられませんか?
結局data[0]['dakoku']と数字の部分がうまく行ってないのかなと思ったのですが、、、、

回答の参考になればと思います。。。

ikuwow👍を押しています

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

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

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

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

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

guest

回答4

0

whileループの閉じる位置が違うため、nameがすべて同じになっているのではないでしょうか?
次のようにするとどうですか?

PHP

1// DBからデータを受け取る 2$row = array(); 3while($row = $stmt->fetch()) { 4 $row['data'][] = array( 5 array( 6 "id" => $row['id'], 7 "name" => $row['name'], 8 "dakoku" => $row['dakoku']), 9 ) 10 ); 11} 12 $row_ct = count($row['data']); 13 14 for($no = 0; $no < $row_ct; $no++) { 15?> 16<form action="update.php" method="post"> 17<tr> 18<td> <?= h($row['data'][$no]['name']); ?> </td> 19<td> <select name="data[<?= $no; ?>]['dakoku']" value="<?= h($row['data'][$no]['dakoku']; ?>"> 20<option <?= $row['data'][$no]['dakoku'] != '出勤' ?: 'selected' ?> value="出勤">出勤</option> 21<option <?= $row['data'][$no]['dakoku'] != '退勤' ?: 'selected' ?> value="退勤">退勤</option> 22<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休入">休入</option> 23<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休戻">休戻</option> 24</select> 25<td> 26<?php } ?> 27</tr> 28<input type="submit" value="保存"> 29

投稿2016/02/19 03:09

orange0190

総合スコア1698

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

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

Z-TALBO

2016/02/19 06:29

回答ありがとうございます! 上記のように、一回whileを閉じるというやり方でやってみました。 その場合、、、、 そもそもデータが表示されないということになってしまいました。。。 例えば2件データがあったときに、その行も出てこない状況、、、 閉じタグを元に戻すと、データは2件あるということで表示されました($row[][]を直してないので、値は出てこなかったですが、、、) endwhile的なやり方でやっているので、まず閉じてしまうとできなくなるのかな? それとも、何かやり方が間違ってしまっているでしょうか?
orange0190

2016/02/19 07:10

修正後コードを載せてください。
guest

0

ベストアンサーが選ばれていますが、$rowは後々使わないということなので、

PHP

1<?php 2// DBからデータを受け取る 3$no = 0; 4while($row = $stmt->fetch()): 5 6?> 7<form action="update.php" method="post"> 8<tr> 9<td> <?= h($row['name']) ?> </td> 10<td> <select name="data[<?= $no ?>]['dakoku']" value="<?=h($row['dakoku']) ?>"> 11<option <?= $row['dakoku'] != '出勤' ?: 'selected' ?> value="出勤">出勤</option> 12<option <?= $row['dakoku'] != '退勤' ?: 'selected' ?> value="退勤">退勤</option> 13<option <?= $row['dakoku'] != '休戻' ?: 'selected' ?> value="休入">休入</option> 14<option <?= $row['dakoku'] != '休戻' ?: 'selected' ?> value="休戻">休戻</option> 15</select> 16<td> 17<?php 18 19 $no++; 20endwhile; 21?> 22</tr> 23<input type="submit" value="保存">

簡単になりました。
こんな感じでいいとおもいますよ。

投稿2016/02/19 10:31

shi_ue

総合スコア4437

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

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

Z-TALBO

2016/02/19 13:51

ベストアンサーをどなたに、、、と悩んでしまって、、、 追加でのコメント大変ありがとうございます! すっきりするんですね! 参考にさせていただきます!
guest

0

ベストアンサー

まず以下のfetchで$rowにクエリの結果を代入してしまってますね。
while( $result = $stmt->fetch()) { のように別の変数名でfetchしないとループ毎に$rowが上書きされています。

PHP

1while($row = $stmt->fetch()) { 2 $row = array( 3 "data" => array( 4 array( 5 "id" => $row['id'],

次に下のselectタグのoptionのソースコードを作成する時に $row['data'][$no]['dakoku'] と同じ配列構造にするなら、$row['data'][] =array( ‥という風に配列要素を追加しないとなりません。

PHP

1while( $result = $stmt->fetch( PDO::FETCH_ASSOC ) ) { 2 $row['data'][] = array( 3 "id" => $result['id'], 4

あとは先の回答者の方のを参考にされたようにwhileループを閉じてからfor文で回せば大丈夫でしょう。
以下確認済検証コードです。

PHP

1 try{ 2 $dsn = 'mysql:dbname=' . $MYDB_NAME . ';host=localhost'; 3 $dbh = new PDO( $dsn, $MYDB_USER, $MYDB_PWORD ); 4 if( $dbh != NULL ) { 5 $sql = 'select id, name, dakoku, hour, minutes from syuttaikin'; 6 $stmt = $dbh->query( $sql ); 7 while( $result = $stmt->fetch( PDO::FETCH_ASSOC ) ) { 8 $row['data'][] = array( 9 "id" => $result['id'], 10 "name" => $result['name'], 11 "dakoku" => $result['dakoku'], 12 "hour" => $result['hour'], 13 "minutes" => $result['minutes'] 14 ); 15 } 16 $dbh = NULL; 17 } 18 } catch ( PDOException $e ) { 19 $err_msg = ('DB Query Error : '.$e->getMessage() ); 20 } 21

投稿2016/02/19 10:02

chinyato

総合スコア241

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

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

Z-TALBO

2016/02/19 10:30

コメントしたのですが、、できておりませんでした。 回答ありがとうございます! 先のサンプルも知識として使ってみていますが、だから、、、こうなって~~って感じでフワフワした感じになっております>< まだ、問題が出てくるかと思いますので、またよろしくお願いいたします。
guest

0

$rowがダブって使われています。
DBから取得する変数を変えればいいんじゃないですか?
この$rowは後で使うから、、保存しているんですよね?

PHP

1<?php 2// DBからデータを受け取る 3$row = array(); 4while($data = $stmt->fetch()) { 5 $row['data'][] = array( 6 array( 7 "id" => $data['id'], 8 "name" => $data['name'], 9 "dakoku" => $data['dakoku'], 10 ) 11 ); 12} 13$row_ct = count($row['data']); 14 15for($no = 0; $no < $row_ct; $no++): 16?> 17<form action="update.php" method="post"> 18<tr> 19<td><?= h($row['data'][$no]['name']) ?> </td> 20<td><select name="data[<?= $no ?>]['dakoku']" value="<?= h($row['data'][$no]['dakoku'] ?>"> 21<option <?= $row['data'][$no]['dakoku'] != '出勤' ?: 'selected' ?> value="出勤">出勤</option> 22<option <?= $row['data'][$no]['dakoku'] != '退勤' ?: 'selected' ?> value="退勤">退勤</option> 23<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休入">休入</option> 24<option <?= $row['data'][$no]['dakoku'] != '休戻' ?: 'selected' ?> value="休戻">休戻</option> 25</select> 26<td> 27<?php endfor; ?> 28</tr> 29<input type="submit" value="保存">

投稿2016/02/19 09:52

編集2016/02/19 10:02
shi_ue

総合スコア4437

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

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

Z-TALBO

2016/02/19 10:00

すみません、回答中に編集しておりました。。。 検証してみます!
shi_ue

2016/02/19 10:03

そもそも、$rowは後で使いますか? 使わないなら、whileループだけでやったほうがいいと思いますよ。もっと短くなりますし。
Z-TALBO

2016/02/19 10:19

ありがとうございます! ちゃんと行が取得できました!!! 値のとり方が少し違っており、どうなのかと思いましたが解決できました! $rowというのは、質問でのコードを見ていただくとおりの部分でしか使用しておりません。 whileループだけでやるというのが、現在の知識ではピンときておりません><
chinyato

2016/02/19 10:29

$rowに入れたのは質問者さんの前の質問がPOSTデータの配列の構造についてだったので、私の回答がPOSTデータと初期データを同じ配列構造で作るサンプルを提示した為だと思います。 shi_ueさんの指摘のようにrowを使いまわしたりしなければwhileループ内でHTMLを作成するのが簡単でしょう。 HTMLのヘッダより前で処理して残業時間とか遅刻の時間など計算したりBODY内でフォームを作るなら、いったんrowに代入しても良いかと思います。(ケースバイケースで)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問