数字操作函数和操作符
数字操作符
- +
示例:
1 2 3 4 5
SELECT 2+3 AS RESULT; result -------- 5 (1 row)
- -
示例:
1 2 3 4 5
SELECT 2-3 AS RESULT; result -------- -1 (1 row)
- *
示例:
1 2 3 4 5
SELECT 2*3 AS RESULT; result -------- 6 (1 row)
- /
示例:
1 2 3 4 5
SELECT 4/2 AS RESULT; result -------- 2 (1 row)
1 2 3 4 5
SELECT 4/3 AS RESULT; result ------------------ 1.33333333333333 (1 row)
- +/-
示例:
1 2 3 4 5
SELECT -2 AS RESULT; result -------- -2 (1 row)
- %
示例:
1 2 3 4 5
SELECT 5%4 AS RESULT; result -------- 1 (1 row)
- @
示例:
1 2 3 4 5
SELECT @ -5.0 AS RESULT; result -------- 5.0 (1 row)
- ^
MySQL兼容模式下,作用为异或,参见位串函数和操作符章节的操作符“#”。
示例:
1 2 3 4 5
SELECT 2.0^3.0 AS RESULT; result -------------------- 8.0000000000000000 (1 row)
- |/
示例:
1 2 3 4 5
SELECT |/ 25.0 AS RESULT; result -------- 5 (1 row)
- ||/
示例:
1 2 3 4 5
SELECT ||/ 27.0 AS RESULT; result -------- 3 (1 row)
- !
示例:
1 2 3 4 5
SELECT 5! AS RESULT; result -------- 120 (1 row)
- !!
示例:
1 2 3 4 5
SELECT !!5 AS RESULT; result -------- 120 (1 row)
- &
示例:
1 2 3 4 5
SELECT 91&15 AS RESULT; result -------- 11 (1 row)
- |
示例:
1 2 3 4 5
SELECT 32|3 AS RESULT; result -------- 35 (1 row)
- #
示例:
1 2 3 4 5
SELECT 17#5 AS RESULT; result -------- 20 (1 row)
- ~
示例:
1 2 3 4 5
SELECT ~1 AS RESULT; result -------- -2 (1 row)
- <<
示例:
1 2 3 4 5
SELECT 1<<4 AS RESULT; result -------- 16 (1 row)
- >>
示例:
1 2 3 4 5
SELECT 8>>2 AS RESULT; result -------- 2 (1 row)
数字操作函数
- abs(x)
返回值类型:和输入相同。
示例:
1 2 3 4 5
SELECT abs(-17.4); abs ------ 17.4 (1 row)
- acos(x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT acos(-1); acos ------------------ 3.14159265358979 (1 row)
- asin(x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT asin(0.5); asin ------------------ .523598775598299 (1 row)
- atan(x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT atan(1); atan ------------------ .785398163397448 (1 row)
- atan2(y, x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT atan2(2, 1); atan2 ------------------ 1.10714871779409 (1 row)
- bitand(integer, integer)
返回值类型:bigint类型数字。
示例:
1 2 3 4 5
SELECT bitand(127, 63); bitand -------- 63 (1 row)
- cbrt(dp)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT cbrt(27.0); cbrt ------ 3 (1 row)
- ceil(x)
返回值类型:整数。
示例:
1 2 3 4 5
SELECT ceil(-42.8); ceil ------ -42 (1 row)
- ceiling(dp or numeric)
返回值类型:与输入相同。
示例:
1 2 3 4 5
SELECT ceiling(-95.3); ceiling --------- -95 (1 row)
- cos(x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT cos(-3.1415927); cos ------------------- -.999999999999999 (1 row)
- cot(x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT cot(1); cot ------------------ .642092615934331 (1 row)
- degrees(dp)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT degrees(0.5); degrees ------------------ 28.6478897565412 (1 row)
- div(y numeric, x numeric)
返回值类型:numeric
示例:
1 2 3 4 5
SELECT div(9,4); div ----- 2 (1 row)
- exp(x)
返回值类型:与输入相同。
示例:
1 2 3 4 5
SELECT exp(1.0); exp -------------------- 2.7182818284590452 (1 row)
- floor(x)
返回值类型:与输入相同。
示例:
1 2 3 4 5
SELECT floor(-42.8); floor ------- -43 (1 row)
- radians(dp)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT radians(45.0); radians ------------------ .785398163397448 (1 row)
- random()
返回值类型:double precision
示例:
1 2 3 4 5
SELECT random(); random ------------------ .824823560658842 (1 row)
- ln(x)
返回值类型:与输入相同。
示例:
1 2 3 4 5
SELECT ln(2.0); ln ------------------- .6931471805599453 (1 row)
- log(x)
- ORA和TD兼容模式下,表现为以10为底的对数。
- MySQL兼容模式下,表现为自然对数。
返回值类型:与输入相同。
示例:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
-- ORA兼容模式 SELECT log(100.0); log -------------------- 2.0000000000000000 (1 row) -- TD兼容模式 SELECT log(100.0); log -------------------- 2.0000000000000000 (1 row) -- MySQL兼容模式 SELECT log(100.0); log -------------------- 4.6051701859880914 (1 row)
- log(b numeric, x numeric)
返回值类型:numeric
示例:
1 2 3 4 5
SELECT log(2.0, 64.0); log -------------------- 6.0000000000000000 (1 row)
- mod(x,y)
x/y的余数(模)
如果x是0,则返回y。
返回值类型:与参数类型相同。
示例:
1 2 3 4 5
SELECT mod(9,4); mod ----- 1 (1 row)
1 2 3 4 5
SELECT mod(9,0); mod ----- 9 (1 row)
- pi()
返回值类型:double precision
示例:
1 2 3 4 5
SELECT pi(); pi ------------------ 3.14159265358979 (1 row)
- power(a double precision, b double precision)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT power(9.0, 3.0); power ---------------------- 729.0000000000000000 (1 row)
- round(x)
返回值类型:与输入相同。
示例:
1 2 3 4 5 6 7 8 9 10 11
SELECT round(42.4); round ------- 42 (1 row) SELECT round(42.6); round ------- 43 (1 row)
当调用round函数时,数值类型将舍入零,而(在大多数计算机上) 实数和双精度型,以最接近的偶数为结果。
- round(v numeric, s int)
返回值类型:numeric
示例:
1 2 3 4 5
SELECT round(42.4382, 2); round ------- 42.44 (1 row)
- setseed(dp)
描述:为随后的random()调用设置种子(-1.0到1.0之间,包含)。
返回值类型:void
示例:
1 2 3 4 5
SELECT setseed(0.54823); setseed --------- (1 row)
- sign(x)
返回值类型:-1表示负数,0表示0,1表示正数。
示例:
1 2 3 4 5
SELECT sign(-8.4); sign ------ -1 (1 row)
- sin(x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT sin(1.57079); sin ------------------ .999999999979986 (1 row)
- sqrt(x)
返回值类型:与输入相同。
示例:
1 2 3 4 5
SELECT sqrt(2.0); sqrt ------------------- 1.414213562373095 (1 row)
- tan(x)
返回值类型:double precision
示例:
1 2 3 4 5
SELECT tan(20); tan ------------------ 2.23716094422474 (1 row)
- trunc(x)
返回值类型:与输入相同。
示例:
1 2 3 4 5
SELECT trunc(42.8); trunc ------- 42 (1 row)
- trunc(v numeric, s int)
返回值类型:numeric
示例:
1 2 3 4 5
SELECT trunc(42.4382, 2); trunc ------- 42.43 (1 row)
- width_bucket(op numeric, b1 numeric, b2 numeric, count int)
描述:返回一个桶,这个桶是在一个有count个桶,上界为b1下界为b2的等深柱图中operand将被赋予的那个桶。
返回值类型:int
示例:
1 2 3 4 5
SELECT width_bucket(5.35, 0.024, 10.06, 5); width_bucket -------------- 3 (1 row)
- width_bucket(op dp, b1 dp, b2 dp, count int)
描述:返回一个桶,这个桶是在一个有count个桶,上界为b1下界为b2的等深柱图中operand将被赋予的那个桶。
返回值类型:int
示例:
1 2 3 4 5
SELECT width_bucket(5.35, 0.024, 10.06, 5); width_bucket -------------- 3 (1 row)