SQL辞典

【SQL算術関数】ROUND – 四捨五入を行う(まるめる)(Oracle、SQL Server)

投稿日:2009年9月11日 更新日:

ROUND関数は数値を四捨五入する関数ですが、MS SQLとOracleでは若干使い方が違います。OracleではROUND関数の引数に指定した数値を四捨五入しますが、MS SQLの場合は四捨五入するか切り捨てるかの指定を行う必要があります。つまり、MS SQLの場合はROUND関数はOracleのTRUNC関数と同じ機能を持つことになります。

文法:

ROUND(value, d [, type] )   SQL Server
ROUND(value [, d] )      Oracle

SQL Serverの場合、typeに従ってvalueの値をdで指定した小数点以下の桁数で四捨五入もしくは切り捨てる。typeに0以外の数値を指定すると、ROUND関数は切り捨てした値を返す。
Oracleの場合、dで指定した小数点以下の桁数で四捨五入する。

使用例:テストの平均点を四捨五入する。(SQL Server)

SELECT score, ROUND(score, 0) FROM tbScoreTable;

score     ROUND(score, 0)
———————————————–
40.323    40.000
63.678    64.000
89.835    90.000

使用例:テストの平均点を小数点2桁まで残して四捨五入する。(Oracle)

SELECT score, ROUND(score, 2) FROM tbScoreTable;

score     ROUND(score, 2)
———————————————-
40.323    40.320
63.678    63.680
89.835    89.840

使用例:テストの平均点を小数点1ケタを残して切り捨てる(SQL Server)

SELECT score, ROUND(score, 1, 1) FROM tbScoreTable;

score     ROUND(score, 1, 1)
———————————————
40.323    40.300
63.678    63.600
89.835    89.800

SQLコマンド辞典に戻る

広告

広告

-SQL辞典


comment

関連記事

no image

【SQL文字列関数】REPLICATE – 指定した文字列を繰り返す(SQL Server)

SQL Serverでは、REPLICATE関数を使って文字列を指定回数繰り返す事ができます。 文法: REPLICATE(s, n) sに指定した文字列をn回繰り返す。 使用例:社員名列をN列の回数 …

no image

【SQL算術関数】GREATEST – 引数の中から最大値を返す (Oracle)

Oracleでは、2つ以上の引数の中から最大値を返すGREATEST関数があります。逆に引数の中から最小値を返すにはLEAST関数を使います。 文法: GREATEST(a, b [, c, &#82 …

no image

【SQL日付関数】MONTH – 日付値から月を取得する(SQL Server)

SQL Serverで日付値から月の値を取得するにはMONTH関数を使います。DATEPART関数を使っても日付型の値から月を取得する事ができます。DATEPART関数とMONTH関数の違いは、DAT …

no image

【SQL日付関数】CURRENT_DATE – 現在の日付を取得する(Oracle)

OracleではCURRENT_DATE関数を使って現在の日付を取得する事ができます。OracleにはSYSDATE関数でも現在の日付を取得する事ができます。CURRENT_DATE関数には括弧は不要 …

no image

【SQL日付関数】NEXT_DAY – 指定した曜日が次に来る日付を求める (Oracle)

OracleではNEXT_DAY関数を利用して、指定した曜日が次に来る日付を求める事ができます。 文法: NEXT_DAY(date, week) dateから見てweekで指定した曜日が来る次の日付 …

広告

転職