PHPでMySQLのデータベースを参照するSQL文を書いています。
room_equipment
というテーブル内に
area
という項目があり、この中は
1,3,5,8
のように、複数の数字がコンマ区切りで入っています。
分からないなりに
<?php if($room_equipment['area']==6){ echo '当たり'; } else { echo '外れ'; } ?>
と書いてみたのですが、これだと、
area
の項目内の先頭に6が来ているときは「当たり」と表示されるものの、
項目内が
1,3,5,6
というような内容のときには「はずれ」と表示されます。
たぶん、== というのは単純に「等しい」ことを差しており、
「含まれている」という意味ではないのではないかと思いました。
いろいろレクチャーサイトをのぞいてみましたが、
「項目に含まれている」ということを指し示す演算子は
どのようなもので、上記のコードはどのように修正すれば良いでしょうか?
どなたか、教えていただけますと大変助かります。
よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
・コンマ区切りの数字の列をコンマで分割し、おのおの数字を配列に格納する
・配列を検索し、値が探している数字である要素があるか調べる
といったことで実現できると思います。
$area_array = explode(',', $room_equipment['area']);
if(in_array('6', $area_array, true)){
echo '当たり';
} else {
echo '外れ';
}
> たぶん、== というのは単純に「等しい」ことを差しており、
> 「含まれている」という意味ではないのではないかと思いました。
「含まれている」という意味ではないですね。
== は「等しい」で大抵うまくいくんですが、
はまることもあります。
> 項目内の先頭に6が来ているときは「当たり」と表示される
この場合、例えば '6,1,3,5' と 6 が等しいと判断されているわけですね。
比較演算子
http://www.php.net/manual/ja/language.operators. …
PHPの==がキモい件
http://d.hatena.ne.jp/hnw/20080606
explode
http://www.php.net/manual/ja/function.explode.php
in_array
http://www.php.net/manual/ja/function.in-array.php
ありがとうございました!
うまく実装できました!
コードを書いていただけたので、
それを分解して考えることができるので非常に参考になりました。
No.1
- 回答日時:
いくつかの考え方があるので紹介します
MySQLで解決する
(1)そもそもSQLをつかっているなら、絞り込みはSQL側で行う
(2)データの持ち方がへんなので正規化をしてデータを個別管理する
PHPで解決する
(3)カンマ区切りならカンマで分かち配列を走査する
<?PHP
$str="1,3,5,8";
if(in_array("5",explode(",",$str))) print "5 ok<br>\n";
if(in_array("6",explode(",",$str))) print "6 ok<br>\n";
if(in_array("8",explode(",",$str))) print "8 ok<br>\n";
?>
(4)正規表現
<?PHP
$str="1,3,5,8";
if(preg_match("/(^|,)5(,|$)/",$str)) print "5 ok<br>\n";
if(preg_match("/(^|,)6(,|$)/",$str)) print "6 ok<br>\n";
if(preg_match("/(^|,)8(,|$)/",$str)) print "8 ok<br>\n";
?>
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP PHP MySql ページング 2 2022/09/20 06:38
- JavaScript セレクトを全て選択されていないと、文字によるエラーメッセージを表示させるコードを調べています 2 2023/06/22 15:48
- Visual Basic(VBA) VBA エクセル 条件の設定 1 2022/03/28 10:24
- Excel(エクセル) 表示形式、文字列セル(列)に数式を入力するには マクロ 1 2022/09/18 10:53
- 作詞・作曲 【花の苗】という言葉は、詩的にはどのような事物を表現しているのでしょうか? 1 2023/03/16 09:23
- Visual Basic(VBA) 【VBA】データを入力後に,同一シート内に履歴として転記するVBAコードを教えていただきたいです。 3 2022/11/16 01:37
- PHP コメント機能に返信欄を矢印で追加したい 1 2022/05/09 21:17
- PHP htmlで複数の個数入力欄を表示させるには 1 2022/09/20 03:11
- Visual Basic(VBA) ExcelVBAでユーザーフォームでテキストボックスなどからセルに連続して入力するコーディングの際の 2 2022/06/29 22:51
- Visual Basic(VBA) VBAで、1つのエクセルで、2つのシートからもう1つのシートに条件のある転記コードを教えてください。 1 2023/03/16 18:07
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
PHPについて教えて下さい。
-
C言語で全角文字の扱いについて
-
PHPのセレクトボックスの初期値...
-
C言語の配列をPush(追加)する...
-
C言語 最大値と最小値を求めて...
-
2次元配列のソート
-
MYSQLとPHPによって取得する多...
-
PHPによる並べ替え(ソーティン...
-
C言語の2次元配列における行・...
-
PHPに関する質問です
-
どのような関数名を付けるべき...
-
配列から値を取得する方法。
-
読み(あ行~わ行)ごとに分け...
-
【PHP】配列に出てくるこの...
-
配列について
-
配列を返す関数から、一つの要...
-
pythonのnumpyでの繰り返しでの...
-
テキストエリアに入力した複数...
-
templateを使ったXOR swapのバ...
-
配列内の値を分解して再格納
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラミングのPythonのnoteb...
-
スカラーのベクトル微分
-
特定の文からメールアドレスの...
-
CArrayの要素としてCStringArra...
-
C言語 最大値と最小値を求めて...
-
行列
-
読み(あ行~わ行)ごとに分け...
-
配列の要素(value)に、変数を...
-
C言語の配列をPush(追加)する...
-
STLのvectorで作った配列をメン...
-
php で1から100までの素数の表...
-
【PHP】配列のキー名の修正は可...
-
Perlで重複行を削除したい
-
fgetc関数について
-
CArrayのソート
-
ファイルの書き込みについて教...
-
配列の添え字が小数だとどうなる?
-
PHPのmin関数、「1」以上の数値...
-
forとかで連番の変数を一気に格...
-
delphi 2次元配列がわかりません
おすすめ情報