Greatest函数
函数结构
greatest( expr1, expr2, ... expr_n )
expr1, expr2, . expr_n 可以值也可以是函数,在比较时,OracIe会自动按表达式的数据类型进行比较,以expr_1的数据类型为准。
函数功能:取得值最大值
规 则:数字按大小排,字符按首字符比较
影响版本: Oracle 8i, Oracle 9i, Oracle 10g, Oracle 11g
示例:
greatest(2, 5, 12, 3) would return 12 greatest('2', '5', '12', '3') would return '5' greatest('apples', 'oranges', 'bananas') would return 'oranges' greatest('apples', 'applis', 'applas') would return 'applis'
部分为数值型,但是字符串不能通过隐式类型转换成数值型会报错,因为字符串A不能转换成数值型:
SQL>SELECT GREATEST(2, 'A', 12, 3, 16, 8, 9) A FROM DUAL;
ORA-01722:无效数字
部分为字符型,会把非字符型转换成字符型:
SQL>SELECT GREATEST('A', 6, 7, 5000, 'E', 'F','G') A FROM DUAL;
返回:G