时间:2021-07-01 10:21:17 帮助过:7人阅读
单值函数一般都比较简单,但是很常用。
他们分别是“+”,“-”,“*”,“/”,很简单,大家都会,不多说,看下简单示例:
- select 3+2,3-2,3*2,3/2 from users;
结果很显然:5 1 6 1.5
我们想将上面的SQL改为与NULL一起运算看下结果如何:
- select 3+NULL,3-NULL,3*NULL,3/NULL from users;
结果将返回:NULL NULL NULL NULL
对,他们的结果都为空,事实上,任何包含NULLDE算术运算都会得到结果NULL。
所以,NULL是不同于0的,NULL不应用来计算。
那么,这也解释了WHERE子句中,不能将NULL与=一起使用:因为如果x=y时,若他们都是NULL,但都是未知的,而实际他们野可能是任何值,使用=是没有意义的。
针对上面的NULL问题,其中一种解决方法就是使用NVL函数。
语法:
NVL(value,substitute)
如果value为NULL,则函数结果为substitute,反之,结果为value。
虽然值为NULL,是未知的,但很多时候可以作一些合理的假设。比如:某列表示某员工的工资,想要计算整个部门一月需要发多少工资,显然是可以预估的,比如采用平均值,这是就可以将NULL值置换为那个平均值,
可以看下使用例子:
- select nvl(NULL,123),nvl(0,123) from users;
结果输出:123 0
NVL的使用不限于数值,他们同样可以适用于其他数据类型,但是要保证value参数和substitute参数类型是相同的。
NVL2
类似的函数是NVL2,语法:
NVL2(e1,e2,e3)
此处e1永远不会被返回,如果e1不为NULL,就返回e2,反之,返回e3。
绝对值这个概念很简单,也不多说了。
语法:
- AB(value)
CEIL用于产生大于或等于当前值的最小整数,当原来那个值为负数时,要留意其结果,看下面示例即可。
语法:
- CEIL(value)
示例:
- select ceil(1),ceil(1.2),ceil(1.5),ceil(1.6),ceil(-2),ceil(-2.4),ceil(-2.5),ceil(-2.6) from users;
结果为:1 2 2 2 -2 -2 -2 -2
FLOOR与CEIL相反,返回小于或等于指定值的最大整数。
语法:
- FLOOR(value)
我们沿用上面的示例:
- select ceil(1),ceil(1.2),ceil(1.5),ceil(1.6),ceil(-2),ceil(-2.4),ceil(-2.5),ceil(-2.6) from users;
结果:1 1 1 1 -2 -3 -3 -3
MOD函数主要用于复杂任务的数据处理,确保一串数字的精确传送。
也就是求余。
格式:
- MOD(value,divisor)
参数可以是任意实数。
示例:
- select mod(50,10),mod(15,4),mod(12.3,5),mod(5.5,2.9),mod(-7,5),mod(0,5),mod(5,0),mod(7,-5) from users;
结果:0 3 2.3 2.6 -2 0 5 2
请注意上面值为0和负数时的结果。
很显然,当divisor为1时,如果value为整数,mod值为0;为0时,结果为value的值。
与MOD函数相似的函数是REMAINDER,不过他们机制不同:MOD在公式中使用FLOOR函数,而REMAINDER使用ROUND函数。
可以看下面的示例对比一下:
POWER用于求一个值的指数乘方。
语法:
- POWER(value,exponent)
例子:
- select power(2,-2),power(-3,-2),power(-3,0),power(-3,1),power(-3,2),power(-3,10),power(1.1,2) from users;
结果:0.25 0.11111111111 1 -3 9 59049 1.21
也就是数学问题了。
通过POWER,我们就可以求得一个数的平方根:POWER(value)
但是Oracle单独提供了一个球平方根的函数:sqrt。
语法:
- SQRT(value)
下面的SQL语句结果是一样的:
- select power(121,0.5) from users;
- select sqrt(121) from users;
他们结果都为 11
Oracle不支持虚数,所以这个value不能为负数,否则会返回错误。
他们是与科学计算相关的函数,商业计算很少涉及。
EXP是e的幂运算;LN是自然对数或以e为底的对数。他们互为反函数。
LOG(e,value)=LN(value)
科学工作者自然会知道他们的含义,此处不多说。
也是两个相关的函数。TRUNC按精读截取某个狮子,ROUND则根据给定的精读舍入数值。
语法:
- ROUND(value,precision)
- TRUNC(value,precision)
对于他们,还是看实际的例子来得比较快:
- select round(11,2),round(11.111,2),round(11.888,2),round(11,-1) from users;
- select trunc(11,2),trunc(11.111,2),trunc(11.888,2),trunc(11,-1) from users;
他们分别返回:
11 11.11 11.89 10
11 11.11 11.88 10
trunc是直接截取,而round会四舍五入处理。
precision参数可以为负数,表示精度移到小数点左边。
ABS返回的是绝对值,即一个数的值大小,不带符号。而SIGN返回的符号。
语法:
- SIGN(value)
示例:
- select sign(-123),sign(0),sign(123) from users;
结果:-1 0 1
一大波数学函数...
SIN、SINH、COS、COSH、TAN、TANH、ACOS、ATAN、ATAN2和ASIN。
我们实际使用是很少的。
如果你确实要使用,那么你数学功底一定不错,那么函数的语法又是很简单的,所以,这里不再演示他们的用法。
聚体函数一般用于统计,把一组值作为操作对象来获得某个结果。
我们要时刻考虑到NULL值会对我们的结果造成怎样的影响。
不同于单值函数,组值函数会忽略NULL值后计算得到结果。
很多时候,这样做事挺好的:如果我们是计算平均数的,使用AVG函数,那么忽略NULL的行计算结果,可能也正是我们期望的工作方式。
但是,倘若上面这个例子,我们不是使用AVG而是SUM,那问题可能就会变得严重了。越多的NULL值,我们所得结果就与我们期望得到的正确结果相差越大。
但是对于这个问题,我们可以借助MAX,MIN等函数,优化我们的处理方式。
当然,COUNT与其他函数会有所不同。
(1)count(*)始终返回总的数据条数
(2)count(field)返回当前字段中不为NULL的个数
组值函数很多时候会与单值函数结合使用。
常用的组值函数是:AVG,COUNT,MAX,MIN,SUM
STDDEV和VARIANCE函数用于常规的统计学功能,分别是标准差和标准方差。
当然,他们也是SQL语言标准所支持的,此处不作介绍了,可以参考:SQL数据库语言总结及代码示例
与ALL对应的就是DISTINCT,语法:
COUNT([DISTINCT|ALL] value)
DISTINCT会强制同名字段只统计一次。
默认使用的是ALL,即检查每一行。
组值函数处理的是一列,而列表函数处理的是一行的一组列。
列表函数可以比较各列,然后选出我们希望得到的一列。
比如,我们要获取同学们左右科目中最高的分数:
- select greatest(english,math,cpp) from grades;
函数GREATEST和LEAST用于返回最大和最小的值。
语法:
GREATEST(value1,value2.value3...)
LEAST(value1,value2.value3...)
他们参数可以是多个,可以使用列、常量、计算结果等。
他们不仅限于数值类型中使用,也可以用于字符串类型。
函数COALESCE用于第一个非NULL的参数,如果所有参数都是NULL,则返回NULL。
语法:
COALESCE(value1,value2.value3...)
可以使用MAX和MIN查找行,然后通过该行获取数据。
在计算和组合多个条件时,我们还要考虑到优先级,比如AND优先级高于OR,如果我们不确定优先级时,或者为了阅读更清晰,请加上括号。