前提・実現したいこと
チェックボックスでチェックしたデータを、データベースに登録したいのですが、うまく登録することができません・・。
arrayデータをデータベースに格納するには、通常のテキストの登録とはちがった処理が必要になるのでしょうか?
ソースコード
下記の$allergyで「かに」「小麦粉」「卵」のようなチェックボックスで選択された複数データを受け取り、データベースに格納しようとしています。
$nameや$addressでは単体のデータを受け取っていますが、こちらはうまく受け取ることができています。
【phpチェックボックス文】
<tr class="form-table-tr">
<th>アレルギー</th>
<td><input type="checkbox" name="allergy[]" value="1">麦
<input type="checkbox" name="allergy[]" value="2">たまご
<input type="checkbox" name="allergy[]" value="3">かに
<input type="checkbox" name="allergy[]" value="4">えび
<input type="checkbox" name="allergy[]" value="5">ピーナッツ
</td>
</tr>
【登録文】
<body>
<?php
$dsn ='mysql:dbname=peco_table;host=localhost';
$user='root';
$password='';
$dbh=new PDO($dsn,$user,$password);
$dbh->query('SET NAMES utf8');
$name=$_POST['name'];
$address=$_POST['address'];
$allergy=$_POST['allergy'];
print 'タイトル';;
print $name;
print "詳細";
foreach($_POST['allergy'] as $value){
echo"{$value},";
}
$sql='INSERT INTO peco_an_table2(name,address,allergy)VALUES("'.$name.'","'.$address.'","'.$allergy.'")';
$stmt=$dbh->prepare($sql);
$stmt->execute();
$dbh=null;
?>
</body>
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
checkベストアンサー
+2
implode
を使ってください。
PHP: implode - Manual
implode
(PHP 4, PHP 5, PHP 7)
implode — 配列要素を文字列により連結する説明
string implode ( string $glue , array $pieces )
string implode ( array $pieces )
配列の要素を glue 文字列で連結します。
<?php
// エラー出力設定
ini_set('display_errors', 1);
ini_set('error_reporting', E_ALL);
var_dump( $_POST['allergy']);
/*
array (size=3)
0 => string '2' (length=1)
1 => string '3' (length=1)
2 => string '4' (length=1)
*/
$allergy = implode(',', $_POST['allergy']);
echo $allergy; // 2,3,4
後々配列に戻したい時などは、explode
を使ってください。
PHP: explode - Manual
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.18%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる