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

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

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

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

Q&A

1回答

535閲覧

5ずつ切り上げするアルゴリズム

JuguarSugar

総合スコア83

Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

0グッド

0クリップ

投稿2022/09/20 07:49

編集2022/09/20 08:37

Oracleにて5ずつ切り上げするアルゴリズムをお教えいただきたいです。
値には0~60しか入りません
【例】
<値> → <求める結果>
0 →  0
1 →  5
5 →  5
7 → 10
17 → 20
20 → 20

エレガントでない書き方だとこんな感じでしょうか
もっとエレガントな書き方はないでしょうか
BEGIN
IF RIGHT(num,1) IN (0,5) THEN
NULL;
ELSIF RIGHT(num,1) >= 4
num := FLOOR(num) + 5;
ELSIF RIGHT(num,1) <= 9
num := ROUND(num,1);
ELSE
END IF;
NULL;
END;

>>質問内容に誤りがありました。

・値は hhmm の形式で入るものになります。
【例】
9時44分 →  944
17時9分 → 1709
・このうち、分数だけ5ずつ切り上げしたいです。
【例】
9時44分 →  945
17時9分 → 1710
9時40分 →  940
17時5分 → 1705

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

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

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

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

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

Zuishin

2022/09/20 08:03

5 で割って小数点以下を切り上げて 5 をかける。
JuguarSugar

2022/09/20 08:18

ありがとうございます! ググっても全然出てこなかったので助かりました!
Zuishin

2022/09/20 08:43

> ・値は hhmm の形式で入るものになります。 算数の問題ですよね? 自分でできると思いますが、考えてみましたか?
JuguarSugar

2022/09/20 08:52 編集

考えてみましたがこんな感じになります。SUBSTRで無理やりmmの箇所を抜き出して計算している状態です。 (num - SUBSTR(num , -2)) + CEIL(SUBSTR(num , -2) / 5) * 5 自分なりにググって、考えた後で質問はしているつもりです。
Zuishin

2022/09/20 08:53

いやググらなくても普通に計算すればいいと思います。
JuguarSugar

2022/09/20 08:55

普通に計算ができませんでした・・・(-_-;)
Zuishin

2022/09/20 09:06

四則演算と切り上げ切り捨てだけでできるので、できなかったという過去形を使うのではなく、少し頑張ってみてください。 さっきも書いたように算数の問題なので、小学生に負けてはいけません。
JuguarSugar

2022/09/21 08:10 編集

頑張ってみます。 >>本当にわかりません。これって四則演算と切り上げ切り捨てだけで出来ますか?
guest

回答1

0

5 で割って小数点以下を切り上げて 5 をかける。

CEIL(num / 5) * 5

投稿2022/09/20 08:18

編集2022/09/20 08:24
JuguarSugar

総合スコア83

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問