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

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

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

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

Q&A

解決済

3回答

20109閲覧

複数のカラムにある数値の合計を計算した上でcountする

leoairen

総合スコア122

MySQL

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

1グッド

1クリップ

投稿2016/07/11 00:04

編集2016/07/11 00:23

複数のカラムにある数値の合計を計算した上でcountするにはどう修正すればよろしいでしょうか。
テーブルにはそれぞれ数値のカラムが三つありまして、三つ目はNULLの場合があります。
やりたいことはそれぞれのカラムを合計した上で、ある数値の範囲内(例:合計が1000~1100以内)にあるものはいくつあるかを計算したいです。なお、一ケタは四捨五入したいです。
下記のように書いてみたのですが、うまくいきません。
どなたか教えて頂けますでしょうか。

SQL

1 2count(Sum(ROUND(a,0)) + Sum(ROUND(b,0)) + COALESCE(SUM(ROUND(c,0)), 0))<1000 >1100 AS goukei1 3count(Sum(ROUND(a,0)) + Sum(ROUND(b,0)) + COALESCE(SUM(ROUND(c,0)), 0))<1100 >1200 AS goukei2 4count(Sum(ROUND(a,0)) + Sum(ROUND(b,0)) + COALESCE(SUM(ROUND(c,0)), 0))<1200 >1300 AS goukei3 5 6あるいは 7 8count(Sum(truncate(a + 5, 0)) + Sum(truncate(b + 5, 0)) + COALESCE(SUM(truncate(c + 5, 0)), 0))<1000 >1100 AS goukei1 9count(Sum(truncate(a + 5, 0)) + Sum(truncate(b + 5, 0)) + COALESCE(SUM(truncate(c + 5, 0)), 0))<1100 >1200 AS goukei2 10count(Sum(truncate(a + 5, 0)) + Sum(truncate(b + 5, 0)) + COALESCE(SUM(truncate(c + 5, 0)), 0))<1200 >1300 AS goukei3 11
mondaminZ👍を押しています

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

masaya_ohashi

2016/07/11 00:10

1クエリでgoukei1、goukei2、goukei3を出すのは必須ですか?
leoairen

2016/07/11 00:17

コメント、ありがとうございます。1クエリとは一回の実行という理解でよろしいでしょうか。一回の実行で出すのは必須です。
guest

回答3

0

なれるまでわかりづらいですが、条件に合致する件数を得るには
sumを利用します。
条件に合致すると1、合致しないと0なので1をsumで積み上げるという考え方

一ケタは四捨五入したいです

合計値を四捨五入するか、それぞれを四捨五入して合計するかによって
若干処理が違うと思います
とりあえずそれぞれを四捨五入する場合、1000も1100も含むのでしたらこんな感じ

SQL

1select sum((round(a)+round(b)+round(coalesce(c,0))) between 1000 and 1100) as cnt 2from テーブル;

含まない場合はちょっと工夫してサブクエリをつかってこう

SQL

1select sum(sum between 1000 and 1100 and not sum in(1000,1100)) count 2from(select (round(a)+round(b)+round(coalesce(c,0))) as sum from テーブル) as sub

あとは範囲を調整してください

投稿2016/07/11 01:05

yambejp

総合スコア114825

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

leoairen

2016/07/11 08:31

ご回答ありがとうございました。masaya_ohashiさんの方法でできました。この書き方も勉強になりました。ありがとうございます。
guest

0

こんなのもできると思います。

SQL

1SELECT 2 SUM(CASE WHEN (ROUND(a,0)+ROUND(b,0)+COALESCE(ROUND(c,0),0)) BETWEEN 1000 AND 1099 THEN 1 ELSE 0 END) AS goukei1, 3 SUM(CASE WHEN (ROUND(a,0)+ROUND(b,0)+COALESCE(ROUND(c,0),0)) BETWEEN 1100 AND 1199 THEN 1 ELSE 0 END) AS goukei2, 4 SUM(CASE WHEN (ROUND(a,0)+ROUND(b,0)+COALESCE(ROUND(c,0),0)) BETWEEN 1200 AND 1299 THEN 1 ELSE 0 END) AS goukei3 5FROM xxxx;

投稿2016/07/11 00:51

dupont_kedama

総合スコア925

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

leoairen

2016/07/11 08:30

ご回答ありがとうございました。できました。この書き方も勉強になりました。ありがとうございます。
guest

0

ベストアンサー

こうですかねぇ。もっと効率いい書き方ある気がしますが…

SQL

1SELECT 2 (SELECT COUNT(*) FROM xxxxx WHERE ROUND(a)+ROUND(b)+ROUND(IFNULL(c,0)) BETWEEN 1000 AND 1099) AS goukei1, 3 (SELECT COUNT(*) FROM xxxxx WHERE ROUND(a)+ROUND(b)+ROUND(IFNULL(c,0)) BETWEEN 1100 AND 1199) AS goukei2, 4 (SELECT COUNT(*) FROM xxxxx WHERE ROUND(a)+ROUND(b)+ROUND(IFNULL(c,0)) BETWEEN 1200 AND 1299) AS goukei3;

http://sqlfiddle.com/#!9/4ab4b/6

投稿2016/07/11 00:22

masaya_ohashi

総合スコア9206

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

leoairen

2016/07/11 08:30

ご回答ありがとうございました。できました。勉強になりました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問