次のようなテーブルで
DROP TABLE IF EXISTS tbl;
CREATE TABLE IF NOT EXISTS tbl (
id int(11) NOT NULL,
type ENUM('a', 'b', 'c') NOT NULL DEFAULT 'a',
val1 int NOT NULL,
val2 double NOT NULL,
PRIMARY KEY(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO tbl (id, type, val1, val2) VALUES (1, 'a', 150, 1.5);
INSERT INTO tbl (id, type, val1, val2) VALUES (2, 'b', 50, 0.3);
INSERT INTO tbl (id, type, val1, val2) VALUES (3, 'c', 5, 0.5);
INSERT INTO tbl (id, type, val1, val2) VALUES (4, 'b', 30, 0.1);
idが4の場合のval2を、それまで(idが1~3)のtypeが'a'と'b'のval1の合計で割った値を求めたいですが、
この例だと
0.1÷(150+50)=0.0005
という結果を得たいのです。
どのようなSQL文にすれば良いのでしょうか?
No.1ベストアンサー
- 回答日時:
select id,val2/(select sum(val1) from tbl where type in ('a','b') and id<4) as val
from tbl where id=4
場合によっていはidの値:4の部分を共通化してこう
select id,val2/(select sum(val1) from tbl where type in ('a','b') and id<(select @a from (select @a:=4) as dummy)) as val
from tbl where id=@a
ご回答ありがとうございます。
なるほど、上のSQL文で求めていた結果が得られました。
ありがとうございます。
ところで、下のSQL文なのですが、これをそのまま実行すると
「返り値が空でした (行数 0)。」
という結果が返ってくるのですが、この文はどのようにして実行すれば良いのでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 次の時間帯の勝率の合計を求めるSQL文 1 2023/07/04 17:12
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- PHP php エラー 2 2022/10/23 16:43
- AJAX JavascriptからPHPへのAjax通信でnullが返ってくる 3 2022/08/03 22:00
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL SHOW CREATE TABLE posts;これって何ですか? 3 2022/08/28 22:57
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
マイクラPC版のコマンドで効率...
-
エクセルで最後の文字だけ置き...
-
阪急三番街 ATM(ゆうちょ)は...
-
同一のユーザー、同一商品のと...
-
Unionした最後にGROUP BYを追加...
-
DataTableで重複行を削除したい
-
書籍の内容はまともでしょうか?
-
副問合せの書き方について
-
SQL Left Join で重複を排除す...
-
WHERE id = ? について
-
min句のSQLを改造し二番目に小...
-
MySQLのint型で001と表示する方...
-
別テーブルからSELECTした値を...
-
所有格の意味
-
select文のwhere句に配列を入れ...
-
スクリーンセイバー
-
MySQLの抽出について
-
ポスグレでの幾何学データ配列...
-
AUTO_INCREMENTのあるテーブル...
-
【MySQL】本当に困っているので...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
select文のwhere句に配列を入れ...
-
selectした大量データをinsert...
-
センノシド異性体構造式
-
Unionした最後にGROUP BYを追加...
-
insertを高速化させたい
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
sqlで、600行あるテーブルを100...
-
エクセルの関数について教えて...
-
Access パラメータクエリをcsv...
-
URL と行番号の指定
-
複数テーブルのGROUP BY の使い...
-
PL/SQLの変数について
おすすめ情報