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

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

ただいまの
回答率

90.38%

  • MySQL

    7289questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

重量に対する送料をSELECTするクエリー文

解決済

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 662
退会済みユーザー

退会済みユーザー

MySQLで重量に対する送料をテーブルからSELECTするクエリーを考えているのですが、なかなか思いつかないのでアドバイスを頂けたらと思い質問させて頂きました。

まず重量に対する送料のテーブルtb_souryouを作ります。
tb_souryou
No, weight, souryou
1,   100,    200
2,   200,    240
3,   300,    280
4,   400,    320
5,   500,    360
6,   750,    440
7,  1000,    620
8,  1500,    940
9,  2000,   1260
tb_souryouのweightはg(グラム)、souryouは円を表しています。

荷物の重量は様々ですが、例えば

・荷物が50gだとしたらtb_souryouからweight = 100のsouryouつまり200円が送料となります。
・荷物が365gだとしたらtb_souryouからweight = 400のsouryouつまり320円が送料となります。
・荷物が1200gだとしたらtb_souryouからweight = 1500のsouryouつまり940円が送料となります。

条件は、
・荷物が1~100gならweight=100のsouryouを取得します。
・荷物が101~200gならweight=200のsouryouを取得します。
・…
・荷物が1501~2000gならweight=2000のsouryouを取得します。
・荷物が2001g以上の場合は結果を返しません(tb_souryouに記録されているweightは2000までなので)。

このように荷物の重量が様々な条件の場合のSELECT souryou FROM tb_souryouはどのようなクエリー文になるのでしょうか?

tb_souryouのweightの値が変更されたとしてもクエリー文を変更しなくても良いようなクエリー文をお願い致します(CASE WHEN weight > 1500 AND weight <= 2000 THEN 1260 みたいに決め打ちのクエリー文ではなく…という意味です)。

どうぞよろしくお願い致します。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+2

まずはサブクエリで条件を満たす重量を求めて、それから重量をキーに値段を引き直す、というような形がいいのではないかと思います。

SELECT souryou FROM tb_souryou WHERE weight = (SELECT MIN(weight) FROM tb_souryou WHERE weight >= 重量)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/10/27 09:55

    これしかないですね

    キャンセル

  • 2015/10/27 10:47

    ありがとうございます!
    意外と簡単なのですね…。うまくできました。

    キャンセル

+2

すでに解決済みではありますが、、

以下のようにORDER BY句とLIMIT句を使用すれば、サブクエリを使わずに求めることができます。
SELECT souryou FROM tb_souryou WHERE weight >= 重量 ORDER BY weight ASC LIMIT 1;
実行結果
mysql> SELECT souryou FROM tb_souryou WHERE weight >= 100 ORDER BY weight ASC LIMIT 1;
+---------+
| souryou |
+---------+
|     200 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT souryou FROM tb_souryou WHERE weight >= 101 ORDER BY weight ASC LIMIT 1;
+---------+
| souryou |
+---------+
|     240 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT souryou FROM tb_souryou WHERE weight >= 2000 ORDER BY weight ASC LIMIT 1;
+---------+
| souryou |
+---------+
|    1260 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT souryou FROM tb_souryou WHERE weight >= 2001 ORDER BY weight ASC LIMIT 1;
Empty set (0.00 sec)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/10/27 11:35

    こちらのほうが良さそうですね・・・!
    MySQLのサブクエリはなるべく使わないほうがいいということをちらほらと聞いていますので・・・。
    ありがとうございます、非常に参考になりました!

    キャンセル

+1

一般的に重量が大きいほど送料も高くなると思いますので、単純に下記のようなSQLでもいいかと。

SELECT MIN(souryou) FROM tb_souryou WHERE weight >= 重量;

例外があるなら、前の回答のサブクエリを使う方法になると思いますが。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/10/27 11:02

    ありがとうございます!
    そうですね、送料が必ず高くなるというレコードの場合はそのほうが簡単ですね!
    例外はないと思いますが、たしかにMINを重量で取得したほうが確実ではあると思うのでサブクエリで取得したいと思います。
    アドバイスありがとうございました!

    キャンセル

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

  • ただいまの回答率 90.38%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • MySQL

    7289questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。