SQL文で、切捨て関数を使わずに小数第2以下を切り捨てて表示する方法を教えてください。
23.27%が今23.3%で表示しているので、23.2%と表示したいのです。
サンプルで以下のものはありますが、
3.000 / 8.000 通常の計算式
( 3.000 * 10 mod 8.000 / 10 ) 小数第2以下を切り捨て
ここで10をかけて10で割る意味が分かりません。
さらに結果をパーセンテージで表示した状態で、小数第2以下を切り捨てて表示したいので、
この計算式では無理なのかな・・と思います。
アドバイス頂けると助かります。宜しくお願いします。
No.1ベストアンサー
- 回答日時:
ご質問文のどこかに手抜かりはありませんか?
だからなかなか回答が寄せられないのだと思います。
さて、3.00÷8.00を小数点1位まで求めるにはこのようにします。
3.00 * 10→30.00
mod(3.00 * 10, 8.00)→6.00
3.00 * 10 - mod(3.00 * 10, 8.00)→24.00
(3.00 * 10 - mod(3.00 * 10, 8.00)) / 8.00→3.000
∴(3.00 * 10 - mod(3.00 * 10, 8.00)) / 8.000 * 10→0.300
プログラミングの世界では常套手段です。
被除数を10倍して計算すると、小数点下第一位の桁が整数部第一位に移ってきます。だから以降は端数が出ないように整数レベルで計算し、最終結果を10で除せば底上げしておいた整数部第一位の桁が小数点下第一位に戻ってくる、という理屈です。
高校の代数では、「1を加えて1を引く」というテクニックを使ったと思いますが、あれと同じです。
mod(a,b)という演算子は、a÷bの余りを整数で求めてくれるので、最初から余りが出ないように被除数から引き去る工夫をするところがポイントです。
No.4
- 回答日時:
あ、また間違えた!
[誤]
∴(3.00 * 10 - mod(3.00 * 10, 7.00)) / 7.00 / 1000 * 100→42.8
[正]
∴(3.00 * 1000 - mod(3.00 * 1000, 7.00)) / 7.00 / 1000 * 100→42.8
でした。ご愛嬌。(^^;
ご回答ありがとうございました。解説いただいたやり方で無事表示できるようになり作業を進めることが出来ました。
ありがとうございました。
No.3
- 回答日時:
3.00÷7.00=0.4285→42.8%の計算法
100.0%まであるわけですから、最大4桁表示ということで、1000倍して1000で割る方針で行きましょう。
3.00 * 1000→3000.00
mod(3.00 * 1000, 7.00)→4.00
3.00 * 1000 - mod(3.00 * 1000, 7.00)→2996.00
(3.00 * 1000 - mod(3.00 * 1000, 7.00)) / 7.00→428.00
∴(3.00 * 10 - mod(3.00 * 10, 7.00)) / 7.00 / 1000 * 100→42.8
以上は前回回答のやり方ですが、1000で除した直後に100を乗じているのは、小数を百分率(%)に直すための操作です。1000で割って100倍するのですから、"1000 * 100"の部分は"10"で置き換えてもOKです。
No.2
- 回答日時:
No.1です。
誤記がありました。
数式の最後の行で、
[誤]
∴(3.00 * 10 - mod(3.00 * 10, 8.00)) / 8.000 * 10→0.300
の最後の演算子を間違えています。
[正]
∴(3.00 * 10 - mod(3.00 * 10, 8.00)) / 8.000 / 10→0.300
質問が不明瞭でほんとにすみません。そんな中、ご回答ありがとうございました。10でかけて後で10で割る意味が分かりました。
あとこの質問にはもうひとつ質問が混ざりこんでいて(そのせいで不明瞭さに拍車がかかってました。すみません・・)、今作成している計算式が率(%)で表示するものなので、3.00÷8.00=0.375の場合、100を掛けて37.5%と表示したいのです。その時もし3.00÷7.00=0.4285のようになった時、42.9%ではなくて、42.8%という風に小数第2位を切り捨てて表示させたい
のですが、この場合どうしたらよいのでしょうか。
上のサンプルってあてはまるのか、どうあてはめればいいのか・・。切捨て関数がないので、計算式でするしかない状態です。
またアドバイスありましたら本当に助かるのですが、甘え甘えですみません。宜しくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセルのセルの書式設定・ユーザー定義の条件設定について 1 2022/08/17 21:56
- Excel(エクセル) 指定した数字まで累計する方法や文字例の抽出について教えてください 4 2022/10/05 21:19
- 教育学 エクセルで小数点以下を四捨五入について教えてください。 2 2023/04/05 17:33
- 会計ソフト・業務用ソフト Excelの計算 2 2022/05/14 18:17
- Excel(エクセル) エクセルのSUM関数について 4 2023/04/18 10:37
- PHP PHP MySql ページング 2 2022/09/20 06:38
- Excel(エクセル) 非表示にしたい行をグループ化して折り畳み 4 2022/09/17 20:17
- その他(データベース) Accessフォームにて指定のフィールドの平均値を小数点第一位で表示できない 2 2022/08/30 17:19
- その他(パソコン・スマホ・電化製品) pthonのframeに演算結果(数値)を表示したい 1 2023/06/05 22:08
- Excel(エクセル) 関数で割合を表示する 2 2022/09/27 06:09
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
65536は2の何乗なのでしょうか?
-
C言語の課題で、1年の秒数を計...
-
排他的論理和 BCC(水平パリテ...
-
EXCELなどで「返す」という表現
-
科学技術計算の仕事について
-
[急募]Pythonについてです。
-
骨折リスク評価のFRAXについて...
-
smartyで計算を行う方法
-
VBAの再計算が反映されない件に...
-
太陽の位置計算のプログラムを...
-
電卓でmodの計算
-
エクセルVBA 他の仕事を止...
-
fortranの練習問題
-
連立方程式を解くプログラムを...
-
形態素解析から単語出現頻度計算
-
工業高校 情報技術基礎問題が...
-
C言語についてです。 再帰を使...
-
プログラムの質問
-
C++言語で、レナードジョーン...
-
傾いた四角形内の範囲の条件式
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
65536は2の何乗なのでしょうか?
-
VBAの再計算が反映されない件に...
-
排他的論理和 BCC(水平パリテ...
-
EXCELなどで「返す」という表現
-
C言語の課題で、1年の秒数を計...
-
バッチファイルでウインドウを...
-
骨折リスク評価のFRAXについて...
-
変化させるセルが変化しない
-
CとFORTRANの計算速度はどちら...
-
なぜオーバーフローになるので...
-
数値計算の高速化 (cos, sin, exp)
-
モジュラス103の計算とは何でし...
-
C# 計算処理中に実行中ウィン...
-
モジュロ
-
60進数の四則計算
-
引き放し法による除算アルゴリ...
-
C言語についてです。 再帰を使...
-
Perlで時間の計算
-
CRC8を教えてください
-
傾いた四角形内の範囲の条件式
おすすめ情報