MySQL 的IFNULL()、ISNULL()和NULLIF()函数

在使用left join等联表查询时,常遇到某些字段为null,一般都在后台语言使用if (a==null) 判断做处理,其实MySQL本身也有一个IFNULL函数可以处理。同时我们也来说说ISNULL()和NULLIF()函数。

分享

一、IFNULL(expr1,expr2)用法

    假如expr1不为NULL,则 IFNULL() 的返回值为expr1; 否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。
      mysql>   SELECT   IFNULL(1,0);   
                            ->   1   
      mysql>   SELECT   IFNULL(NULL,10);   
                            ->   10   
      mysql>   SELECT   IFNULL(1/0,10);   
                            ->   10   
      mysql>   SELECT   IFNULL(1/0,'yes');   
                            ->   'yes'  
      IFNULL(expr1,expr2)的默认结果值为两个表达式中更加“通用”的一个,顺序为STRING、REAL或 INTEGER。

项目中具体代码

[csharp] view plain copy
print ?
  1.   public static List<ta_activity_info> ChooseByActivityID(string ActivityID)  
  2.       {  
  3.           string strSql = @"SELECT DISTINCT  
  4.     @ActivityID as ActivityID,  
  5.    IFNULL(ta_choujiang.CreateTime,(SELECT ta_activity_info.CreateTime from ta_activity_info where ta_activity_info.ActivityID=@ActivityID))as CreateTime,  
  6.     (  
  7.         SELECT  
  8.             count(*)  
  9.         FROM  
  10.             ta_choujiang  
  11.         WHERE  
  12.             ta_choujiang.ActivityID = @ActivityID  
  13.     ) AS PeopleSum,  
  14.     (  
  15.         SELECT  
  16.             count(*)  
  17.         FROM  
  18.             ta_wininfo  
  19.         WHERE  
  20.             ta_wininfo.ActivityID = @ActivityID  
  21.     ) AS zhongjiangPeople,  
  22.     (  
  23.         SELECT  
  24.             (  
  25.                 (  
  26.                     SELECT  
  27.                         count(*)  
  28.                     FROM  
  29.                         ta_choujiang  
  30.                     WHERE  
  31.                         ta_choujiang.ActivityID = @ActivityID  
  32.                 ) - (  
  33.                     SELECT  
  34.                         count(*)  
  35.                     FROM  
  36.                         ta_wininfo  
  37.                     WHERE  
  38.                         ta_wininfo.ActivityID =@ActivityID  
  39.                 )  
  40.             )  
  41.     ) AS weizhongjiangPeople  
  42. FROM  
  43.     ta_activity_info  
  44. LEFT JOIN ta_choujiang ON ta_activity_info.ActivityID = ta_activity_info.ActivityID  
  45. and ta_choujiang.ActivityID =@ActivityID";  
  46.   
  47.           //参数赋值  
  48.           MySqlParameter[] param =  
  49.                        {  
  50.                           new MySqlParameter("@ActivityID", MySqlDbType.VarChar)  
  51.                        };  
  52.           param[0].Value = ActivityID.ToString();  
  53.           //return GetList2<ta_rewardinfo>(strSql, param);  
  54.           List<ta_activity_info> List = GetListV3<ta_activity_info>(strSql, param);  
  55.           return List;  
  56.       }  
  public static List<ta_activity_info> ChooseByActivityID(string ActivityID)
      {
          string strSql = @"SELECT DISTINCT
	@ActivityID as ActivityID,
   IFNULL(ta_choujiang.CreateTime,(SELECT ta_activity_info.CreateTime from ta_activity_info where ta_activity_info.ActivityID=@ActivityID))as CreateTime,
	(
		SELECT
			count(*)
		FROM
			ta_choujiang
		WHERE
			ta_choujiang.ActivityID = @ActivityID
	) AS PeopleSum,
	(
		SELECT
			count(*)
		FROM
			ta_wininfo
		WHERE
			ta_wininfo.ActivityID = @ActivityID
	) AS zhongjiangPeople,
	(
		SELECT
			(
				(
					SELECT
						count(*)
					FROM
						ta_choujiang
					WHERE
						ta_choujiang.ActivityID = @ActivityID
				) - (
					SELECT
						count(*)
					FROM
						ta_wininfo
					WHERE
						ta_wininfo.ActivityID =@ActivityID
				)
			)
	) AS weizhongjiangPeople
FROM
	ta_activity_info
LEFT JOIN ta_choujiang ON ta_activity_info.ActivityID = ta_activity_info.ActivityID
and ta_choujiang.ActivityID =@ActivityID";

          //参数赋值
          MySqlParameter[] param =
                       {
                          new MySqlParameter("@ActivityID", MySqlDbType.VarChar)
                       };
          param[0].Value = ActivityID.ToString();
          //return GetList2<ta_rewardinfo>(strSql, param);
          List<ta_activity_info> List = GetListV3<ta_activity_info>(strSql, param);
          return List;
      }

二、ISNULL(expr) 的用法

    如expr 为null,那么isnull() 的返回值为 1,否则返回值为 0。 
    mysql> select isnull(1+1);
                       -> 0
    mysql> select isnull(1/0);
                       -> 1
    使用= 的null 值对比通常是错误的。

三、NULLIF(expr1,expr2)用法

    如果expr1 = expr2 成立,那么返回值为NULL,否则返回值为expr1。这和CASE  WHEN expr1 = expr2 THEN NULL ELSE   expr1 END相同。     
    mysql>   SELECT NULLIF(1,1);   
                     ->   NULL   
mysql>   SELECT   NULLIF(1,2);   
                     ->   1  
    如果参数不相等,则 MySQL 两次求得的值为 expr1。

总结

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值