主页 > 知识库 > MySQL IFNULL判空问题解决方案

MySQL IFNULL判空问题解决方案

热门标签:南通自动外呼系统软件 申请外呼电话线路 湖南人工外呼系统多少钱 日照旅游地图标注 石家庄电商外呼系统 广东人工电话机器人 信阳稳定外呼系统运营商 百度地图图标标注中心 芒果电话机器人自动化

问题:mybatis返回的null类型数据消失,导致前端展示出错

思路:如果查询出的结果是空值,应当转换成空字符串。当然在前端也能进行判断,但要求后台实现这个功能。

解决方案:

  使用如下方法查询:

  SELECT IFNULL(sex,'') AS sex FROM user --如果查询到这个sex为null值,那么就赋值成空字符串

  不过,如果查询语句本身为null,那么返回前端的还是null,这个就要在代码里判断了。
  比如:

  SELECT IFNULL(sex,'') AS sex FROM user WHERE id=100

  这条语句本身的返回结果是null,它也就不会执行IFNULL函数了,最后的返回结果当然也是null

  所以我的方法是在代码中增加判断:

  if(ansList == null || ansList.size() == 0){...}

MYSQL IFNULL(expr1,expr2)函数

如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2。IFNULL()返回一个数字或字符串值,取决于它被使用的上下文环境。

mysql> select IFNULL(1,0);  
           -> 1  
mysql> select IFNULL(0,10);  
           -> 0  
mysql> select IFNULL(1/0,10);  
           -> 10  
mysql> select IFNULL(1/0,yes);  
           -> yes  

IF(expr1,expr2,expr3)函数

如果expr1是TRUE(expr1>0且expr1>NULL),那么IF()返回expr2,否则它返回expr3。IF()返回一个数字或字符串值,取决于它被使用的上下文。

mysql> select IF(1>2,2,3);  
           -> 3  
mysql> select IF(12,yes,no);  
           -> yes  
mysql> select IF(strcmp(test,test1),yes,no);  
           -> no  
  
expr1作为整数值被计算,它意味着如果你正在测试浮点或字符串值,你应该使用一个比较操作来做。    
  
mysql> select IF(0.1,1,0);  
           -> 0  
mysql> select IF(0.1>0,1,0);  
           -> 1 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • MySql中 is Null段判断无效和IFNULL()失效的解决方案
  • mysql中null(IFNULL,COALESCE和NULLIF)相关知识点总结
  • mysql中替代null的IFNULL()与COALESCE()函数详解
  • 浅谈Mysql中类似于nvl()函数的ifnull()函数
  • MySql中的IFNULL、NULLIF和ISNULL用法详解
  • 浅谈SQLServer的ISNULL函数与Mysql的IFNULL函数用法详解
  • mysql中IFNULL,IF,CASE的区别介绍
  • MySQL ifnull的嵌套使用说明

标签:公主岭 牡丹江 天津 合肥 阿里 呼和浩特 惠州 沈阳

巨人网络通讯声明:本文标题《MySQL IFNULL判空问题解决方案》,本文关键词  MySQL,IFNULL,判空,问题,解决方案,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《MySQL IFNULL判空问题解决方案》相关的同类信息!
  • 本页收集关于MySQL IFNULL判空问题解决方案的相关信息资讯供网民参考!
  • 推荐文章