• SQL 函数NULLIF、NULL、ISNULL、COALESCE、IIF


    NULLIF函数
    
      NULLIF(Expression1,Expression2):给定两个参数Expression1和Expression2,如果两个参数相等,则返回NULL;否则就返回第一个参数。
    
      等价于:Case WHEN Expression1=Expression2 Then NULL ELSE Expression1。
    
      例如Select NULLIF(1,1)返回NULL,Select NULLIF(1,2)返回1。
    
      有一个实际的应用,例如防止除0操作的放生,可以使用a/NULLIF(b,0),这样就不怕b是0了,当然除0操作也可以通过别的方式判断。
    
    NULL
    
      NULL是个神奇的东西,表示空值,未知值,任何数与它加减乘除都返回NULL。
    
    ISNULL函数
    
      ISNULL(Expression1,Expression2):给定两个参数Expression1和Expression2,如果Expression1是NULL,那么返回Expression2,否则返回Expression1。
    
      等价于:Case WHEN Expression1 is NULL Then Expression2 ELSE Expression1。
    
      例如Select ISNULL(NULL,1)返回1,Select ISNULL(1,2)返回1。
    
      有一个实际的应用,可以对空值进行默认值替代,例如SELECT ISNULL(email,'没有填写email') from table1,所有email为null的,用'没有填写email'来替代。
    
     COALESCE函数
    
      COALESCE(Expression1,Expression2,Expression3,......):接受一系列的表达式或列,返回第一个非空的值。
    
          例如SELECT COALESCE(NULL,NULL,4,NULL,NULL,5),那么返回,如果里面的参数都为NULL,那么会报错。

     Syntax

    IIF ( boolean_expression, true_value, false_value )

    select iif(30>45,'','') as 结果  
    /*  
    结果  
    ----  
    错  
    */  
    select iif(null=null,'','') as 结果  
    /*  
    结果  
    ----  
    错  
    */  
    select iif(null is null,'','') as 结果  
    /*  
    结果  
    ----  
    对  
    */ 

    WITH TIES

      与top()和order by 一起用,可以返回多于top的行。防止丢失想要的信息。

      例如:有个表table1

    select top(3) * from table1 order by name desc:结果如下:(只有三条)

    select top(3) with ties * from table1 order by name desc:结果如下:

    小插件,SQL Prompt,配合Microsoft SQL Server Management Studio,使用起来非常方便,同时再加上以下几个快捷键:

      (1)ctrl+5或F5,运行代码,如果想运行特定的语句,那么只是选中该语句,然后F5或ctrl+E即可。

      (2)ctrl+L:显示执行计划。

      (3)ctrl+R:显示隐藏下面的结果窗口,增大自己书写sql的空间。

  • 相关阅读:
    centos7下git服务器端搭建(转)
    IDEA各个版本激活(亲测有效,永久有效)(转)
    维护贴--linux下 mysql数据库的备份和还原 (转)
    维护贴--验证可用--mysql给root开启远程访问权限,修改root密码(转)
    开通mysql root 用户远程访问权限(转)
    安装mysql时包冲突解决方法
    mysql5.5 for linux 安装(转)
    Centos中iptables和firewall防火墙开启、关闭、查看状态、基本设置等(转)
    一个div宽度不固定的左右居中效果
    多行文字在一个div中上下左右居中
  • 原文地址:https://www.cnblogs.com/shy1766IT/p/6725581.html
Copyright © 2020-2023  润新知