国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

php - MYSQL で 20-35 のような形式で年齢グループ フィールドの範(fàn)囲検索を?qū)g行するにはどうすればよいですか?
代言
代言 2017-06-10 09:47:49
0
8
1152

mysqlには年齢層を格納するフィールドageがあり、形式は図のとおりで、0-0の場合は無制限です

現(xiàn)在の要件は、年齢グループに基づいて検索することです。たとえば、25 歳から 34 歳までのすべてのデータを検索したいと考えています。

その後、問題が発生します。where で and を使用すると、結(jié)果はほとんど得られず、ほとんど何も得られません。or を使用すると、結(jié)果は多くなりますが、結(jié)果が正確ではないことは明らかです。正確に検索するにはどうすればよいですか

ご回答ありがとうございます?,F(xiàn)在私が使用している方法は

です。

SELECT age FROM jobs
WHERE ((substring_index(age,'-',1) >= 16 OR substring_index(age,'-',-1) = 0 ) OR (substring_index(age,'-',-1) <= 24)) AND !(substring_index(age,'-',1) = 0 AND substring_index(age,'-',-1) = 0) ;

ほとんど使えないけど、何か違和感がある

代言
代言

全員に返信(8)
劉奇

おっしゃるとおり、30-55が25-34と一致する場合は、こうなる可能性があります

リーリー
洪濤

これは判斷が難しいですが、30~55はあなたが望む25~34の條件を満たしていますか?それとも25~34以內(nèi)でなければならないのでしょうか?それはあなたの具體的な要件によって異なります

扔個三星炸死你

なぜデータテーブル構(gòu)造がこのように設(shè)計(jì)されているのか、非常に興味があります。なぜ年齢を保存しないのですか? テーブル構(gòu)造がこのように設(shè)計(jì)されている場合、なぜ 25 歳から 34 歳までのデータを取得する必要があるのでしょうか?あなたの年齢は指定された範(fàn)囲にすぎず、特定の値ではありません。テーブルの構(gòu)造を再設(shè)計(jì)し、誤って間違いをしないようにする必要があります。

伊謝爾倫

1. このように年齢グループを保存する場合、年齢範(fàn)囲を區(qū)別するために別のキーを作成する必要がありますか?
2. スクリーンショットには 1-5、2-6、3-4 などのスパンのデザインも表示されています。ユーザーが 3 を選択した場合、どれを選択する必要がありますか?

代言

MySQL の組み込み関數(shù)を理解していない多くの人が、他人に適當(dāng)な指導(dǎo)を行っています

為情所困

問題の原因はデータベース設(shè)計(jì)に無理がある

滿天的星座

抽象的な思考を使って振り返ることをお勧めします。テーブルの年齢フィールドに格納されている情報(bào)をセット A として考え、どこにある條件をセット C として考えます。最終的な結(jié)果はどのような狀況を満たす必要がありますか?

  1. セット A とセット C には交差があります

  2. セット A はセット C のサブセットです

  3. 集合 C は集合 C そのものです

これに基づいて、現(xiàn)在のテーブル構(gòu)造は明らかに適切ではありません。データの量が大きくない場合は、オフラインでデータをクリーンアップし、年齢フィールドを下限と上限に分割してから、コレクション フィルタリング方法を使用できます。たくさん。

伊謝爾倫

あなたのテーブル構(gòu)造ではあなたが言及した機(jī)能を?qū)g現(xiàn)できません

最新のダウンロード
詳細(xì)>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート