いつもお世話になります。
1千件ほどのデータからいろいろな条件でデータの絞込みをしたいの
ですが、初歩的な質問で分かりにくいかもしれませんが、御指導
お願いします。
全国の求人情報サイトのように、
市町村テーブル 企業テーブル 条件テーブル 時給
中京区 花屋 毎日 800円以上
下京区 八百屋 週末だけ 900円以上
上京区 魚屋 平日昼間 1,000円以上
左京区 文房具店 夜専門
右京区 旅館
こんな感じでSQLでテーブルを作っています。
これを検索で絞込みたいのですが、
市町村→企業→条件→時給と全部を絞り込んだり、1つだけの条件
で絞込み方法はわかるのですが、
ある場合は二つだけ、例えば企業と時給で検索をかけたり
ある場合は、市町村と条件と時給で検索をかけたりして
絞込み結果を出したいのですが、
値のない項目があるとその項目の該当条件がないために
検索結果がなしになります。
同じページにリンクを貼って、GETで値を渡して、絞込みを
したいと思っているのですが、よいお知恵をお願いします。
一番基礎的なところからご指導を頂けるとうれしいです。
こんな感じのHPが理想です。
http://www.jobengine.jp/search.html?p=lsk26
No.2ベストアンサー
- 回答日時:
WHERE条件で likeを使う手もあるかと思います。
#時給条件、なしの場合
if($jikyu == ""){
$other = "";
}
#時給条件、ありの場合
else {
$other = "and jikyu >= '$jikyu'"
}
WHERE shicho like '%$shicho%' and kigyo like '%$kigyo%' and joken like '%$joken%' $plus
市町村、企業、条件はlike '% %' でも大丈夫じゃないでしょうか。時給は~円以上を使う場合if分で条件式を変えてあげればいいと思います。
ありがとうございます。
現在チャレンジ中です。
like '% %'でも大丈夫ということなのですが、
この内容がイマイチ理解できないのと
最後の$plusというのも何かを意味しているのでしょうか?
変数として追加するものがあればというような
ことなのか、このような記述が必要なのか
シンクタンクエラーとなってしまいうまく行って
くれないので、現在奮闘中です。
No.3
- 回答日時:
like '% %' なら
もし 中央区なら like '%中央区%' となり
指定なしでも like '%%' となり 全てを検索してくれます。
$plusは、間違えました。
$plusじゃなくて$otherです。
『時給条件を加える』という意味です。
No.1
- 回答日時:
こんにちは。
GETで値を取得するのですから、後はその値を見て検索条件があれば、Where句に追加していけばいいだけです。
GETで取得するパラメータ
市町村,企業,条件,時給
と検索条件変数
$jouken="";(検索条件には初期でnullを代入)
あとはパラメータの値を見て、
if(isset(市町村) and 市町村 != ""){
if($jouken == ""){
$jouken = "WHERE 市町村テーブル = 市町村";
}else{
$jouken .= " AND 市町村テーブル = 市町村";
}
}
ってな感じですべてのパラメータに対して同じ処理をすればOKです。
処理のイメージは
1、パラメータ市町村の値があれば、検索条件に加える。
2、$joukenがnull 検索条件が何もなければ、
新しく条件の追加、
すでに条件があれば、
andで条件の追加
をしています。
簡単ですみませんが、大体の考え方がわかるかと思いますので、後はがんばってください。
そうそうに御指導を頂き、ありがとうございます。
なぜか、シンクタンクエラー'{'となってしまいます。
原因を考えたりしていて返信が遅くなりました。
ただ発想の仕方はなんとなく理解できたので、
ただ今チャレンジ中です。
ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excel Powerクエリーの質問、行数指定は可能でしょうか? 2 2022/08/22 12:54
- Excel(エクセル) 【Excel】住所に郵便番号を付記する方法 3 2022/05/07 17:15
- バス・高速バス・夜行バス 高速バス 5 2022/06/23 20:46
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- その他(プログラミング・Web制作) Sikulix2.0.5(Jython2.7.3)でcsvを読込WEB検索条件にpasteで文字化け 1 2023/03/31 11:02
- MySQL PhpMyAdminで作成して実行せよ。 東京23区を、皇居を中心とした4つのエリア(南東, 南西, 1 2023/06/11 11:58
- Outlook(アウトルック) Outlookについて教えてください。 分類項目がついているメールに対して、 以下のような絞り込み( 2 2023/04/29 08:20
- その他(Microsoft Office) Outlookについて教えてください。 分類項目がついているメールに対して、 以下のような絞り込み( 1 2023/04/28 19:22
- 転職 長く続けられる好条件の求人でしょうか? 3 2023/07/12 18:45
- MySQL SQLです。こんな感じですか?あってますか? うまくいきません教えてくださいお願いします 1 2023/07/08 15:27
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
MySQLでデータベースにデータin...
-
クエリObjectをforeachで回す時...
-
csvをDBへ読み込んだら、NULLが...
-
access → Oracleへのデータ移...
-
php+mysqlでポータルサイトを作...
-
結合したテーブルの特定カラム...
-
php mysqlを使用してのリーグ表...
-
メニューの階層について
-
PHP+MYSQLでレコードをランダ...
-
任意の値の取得
-
実行時エラー3131 FROM 句の構...
-
ASPでRecordCountが使用でき...
-
会員登録したらメールが送られ...
-
MYSQL、PHPを使ってのデータと...
-
PHP+mysqlでSQL文に文字数制限...
-
チェックボックスの値の受け渡し
-
抽出結果に番号を振る方法につ...
-
SQLインジェクション対策
-
SQL文が実行できません
-
insert1つの処理でもトランザ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
MySQLでデータベースにデータin...
-
csvをDBへ読み込んだら、NULLが...
-
変数にNULLを代入したい
-
phpにて出欠登録管理を作成して...
-
OracleからAccessへのインポート
-
php sqlite count 列数取得
-
DB Error: no such field
-
日またぎの計算
-
SQLiteでDBに書き込みできません
-
Accessへ日付をINSERT
-
出勤表の作り方
-
PHPとMySQLを使った検索システ...
-
テーブルの数
-
結合したテーブルの特定カラム...
-
PHPでmySQLのテーブルを作成したい
-
PHP データの抽出&相関検定の...
-
SQLで返り値が空とでる
-
phpでテーブルを作る際変数によ...
-
メニューの階層について
-
【PHPとDBの連動】時刻表作成
おすすめ情報