sql语言中的concat函数和nvl函数二者有啥区别?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql语言中的concat函数和nvl函数二者有啥区别?相关的知识,希望对你有一定的参考价值。

完全不同的两个函数,concat函数是把参数转化成字符串然后连接起来返回,如果有参数中有一个是Null的话就返回null,concat('A','B')返回结果就是'AB',
Nvl函数
是返回Null的替代值,有两个参数,例如
Nvl(Parameter1,Parameter2),如果Parameter1是Null,那就返回Parameter2,如果Parameter1不是Null,那就返回Parameter1。还有一个类似的函数是Nvl2,Nvl2函数有3
个参数,例如Nvl2(Parameter1,Parameter2,Parameter3),如果Parameter1不为null返回Parameter2,否则返回Parameter3
参考技术A 搜一下:sql语言中的concat函数和nvl函数二者有什么区别?

ORACLE NVL 和 NVL2 函数的使用

NVL函数是一个空值转换函数,在SQL查询中主要用来处理null值。在不支持 null 值或 null 值无关紧要的情况下,可以使用 NVL( ) 来移去计算或操作中的 null 值。

Oracle在NVL函数的功能上扩展,提供了NVL2函数,使得不论目标值是否为null都能返回自定义的值。

工具/原料

  • ORACLE 11g R2 
  • PL/SQL Developer

方法/步骤

  1.  

    1.NVL ( )语法:nvl(expr1,expr2)

    如果 expr1 是 null 值,则 nvl 函数返回 expr2 ,否则就返回 expr1 。 

    说明:参数 expr1、expr2 可以是任何数据类型,但应该保持相同。若两者数据类型不一致,则Oracle数据库会隐式的转换其中一个的数据类型使其保持和另一个一致,若无法转换则会返回错误。隐式转换的实施规则如下:

     

         (1)若 expr1 是字符数据,则Oracle数据库在比较之前就会把 expr2 转换成 expr1 的数据类型并且返回 VARCHAR2 数据类型到 expr1 的字符集。

         (2) 若 expr1 是数值型,则Oracle数据库决定哪个参数具有最高数值优先级,并把另一个参数的数据类型隐式转换成这种数据类型,并返回这种数据类型的数据。

    实例:返回员工姓名和奖金,若该员工没有奖金则返回 Not Applicable

       SELECT last_name, NVL(TO_CHAR(commission_pct), ‘Not Applicable‘)        "COMMISSION" 

       FROM employees 

       WHERE last_name LIKE ‘B%‘ 

       ORDER BY last_name; 

    技术分享
  2.  

    2.NVL2 ( )

    语法:nvl2(expr1,expr2,expr3)

    如果 expr1 不是 null 值,则 nvl 函数返回 expr2 ,否则就返回 expr3 。参数可以返回任何数据类型的值,但是 expr2 和 expr3 不能是 LONG 型的数据类型。

    说明:若 expr2 和 expr3 的数据类型不同:

         (1)若 expr2 是字符数据,则Oracle数据库在比较之前就会把 expr3 转换成 expr2 的数据类型除非 expr3 是null。在 这种情况下,隐式数据转换是不必要的。Oracle数据库返回 VARCHAR2 数据类型到 expr2 的字符集。

          (2) 若 expr2 是数值型,则Oracle数据库决定哪个参数具有最高数值优先级,并把另一个参数的数据类型隐式转换成这种数据类型,并返回这种数据类型的数据。

    实例:返回员工收入,看员工收入(income)是否由工资(salary)加奖金(commission)组成,这取决于commission_pct列是否为null

       SELECT last_name, salary, NVL2(commission_pct, salary + (salary *       commission_pct), salary) income FROM employees 

       WHERE last_name like ‘B%‘ 

       ORDER BY last_name; 

    技术分享
     

以上是关于sql语言中的concat函数和nvl函数二者有啥区别?的主要内容,如果未能解决你的问题,请参考以下文章

oracle中nvl()函数有啥用啊?

oracle中nvl()函数有啥用啊?

oracle中decode函数有啥用?

nvl、nvl2、nullif、coalesce函数的区别

在c语言编程中,传值方式和传引用方式之间有啥区别?

sql