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

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

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

COUNT は、広く使用されているSQLの関数です。COUNT関数は、行数、もしくは配列のエンティティの数をカウントします。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1141閲覧

Rails 計算ができない。

kuno

総合スコア5

COUNT

COUNT は、広く使用されているSQLの関数です。COUNT関数は、行数、もしくは配列のエンティティの数をカウントします。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/04/25 15:43

お恥ずかしながら計算が期待する動きをせずに困っています。
やりたいことは勝率の計算です。

def win_trade_count(current_user) trades = Trade.where("trades.user_id" => current_user.id) win_trades = trades.where("trades.result" => "勝").count (win_trades / trades.count).to_f end

現状 win_tradeには3、 trades.countには6の値が入っています。これはbyebugで確認しました。
なので返ってきて欲しい値としては0.5です。
ですが、最終的な式を実行すると0.0になって値が返ってきてしまいます。

例えば以下のようにどちらも同じ変数にすれば期待する動きになります。

(win_trades / win_trades).to_f (trades.count / trades.count).to_f どちらもちゃんと1.0が返ってくる。

とても基礎的な部分のことだとは思うのですが、どうしても分からずに今回質問させていただきました。
よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

もしかしたら数値の型を整数(integer)で指定してて、計算結果の0.5が切り捨てで0になってるかもです。
型を浮動小数点数(float)にしたら行けるかもです。
間違ってたらすみません。

投稿2020/04/25 18:22

Kazuki_Naruse

総合スコア63

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

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

kuno

2020/04/25 23:00

to_fを変数につけたら期待する動きになりました! ありがとうございます!
Kazuki_Naruse

2020/04/25 23:02

解決できて良かったです!! Rails頑張ってください!
kuno

2020/04/26 03:47

ありがとうございます! 頑張ります!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問