人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

SQLに関して質問です。

列A 名前
列B 投資金額
列C 配当金額

というテーブルがあります。

列A 列B 列C
木村 100 200
山田 100 0
伊藤 200 540
木村 120 140
山田 500 240
伊藤 420 140

データは上記の通りです。

同一の名前はグルーピングし、利益率(配当/投資)を算出し、利益率の高い順に並び替えしたいと思います。

つまり結果は以下の通りです。

木村154.5%
伊藤109.7%
山田40.0%

SQLでこれを行う事は可能でしょうか?
可能ならばSQL文を教えていただければと思います。

宜しくお願い致します。

ソフトはMYSQLの5.1.22です。

●質問者: ruijio
●カテゴリ:ウェブ制作
✍キーワード:109 グルーピング ソフト データ 伊藤
○ 状態 :終了
└ 回答数 : 2/2件

▽最新の回答へ

1 ● un0
●35ポイント

select 名前,sum(配当金額)/sum(投資金額) as 利益率

from テーブル名

group by 名前

order by 2 desc

こんな感じでいかがでしょうか。

◎質問者からの返答

ありがとうございます。

解決しました


2 ● chuken_kenkou
●35ポイント ベストアンサー

まず、利益率を表示するSQL例です。

select 名前,sum(配当金額)/sum(投資金額)*100 as 利益率
 from tbl1
 group by 名前
 order by 利益率 desc

小数点以下1桁まで求める(2桁目で四捨五入)場合のSQL例です。

select 名前,round(sum(配当金額)/sum(投資金額)*100,1) as 利益率
 from tbl1
 group by 名前
 order by 利益率 desc
◎質問者からの返答

有難うございます。

後者のサンプルで処理する事ができました。

有難うございます。

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ