mybatis xml if 判断为空

1.判断集合是否为空

@Ognl@isNotEmpty可以用来判断集合,字符串是否为空

    <if test="partAttributeList != null and partAttributeList.size > 0">
或者<if test="@Ognl@isNotEmpty(partAttributeList)">

2.判断字符串是否为空

 <if test="attributeValueId != null and attributeValueId != '' ">
或者
 <if test="@Ognl@isNotEmpty(attributeValueId)">
  1. boolean 类型的判断
-- hasRelated是boolean类型
-- 方案一
 <if test="hasRelated != null and 'true'.toString() == hasRelated.toString()">
 
 --方案二 即使是包装类型Boolean,也不需要判断null的问题
<if test="hasRelated">
  1. 模糊查询连接
 name like concat('%', #{name}, '%');

自定义Ognl类:

import java.lang.reflect.Array;
import java.util.Collection;
import java.util.Map;

public class Ognl {
    public Ognl() {
    }

    public static boolean isEmpty(Object o) throws IllegalArgumentException {
        if (o == null) {
            return true;
        } else {
            if (o instanceof String) {
                if (((String) o).length() == 0) {
                    return true;
                }
            } else if (o instanceof Collection) {
                if (((Collection) o).isEmpty()) {
                    return true;
                }
            } else if (o.getClass().isArray()) {
                if (Array.getLength(o) == 0) {
                    return true;
                }
            } else {
                if (!(o instanceof Map)) {
                    return false;
                }

                if (((Map) o).isEmpty()) {
                    return true;
                }
            }

            return false;
        }
    }

    public static boolean isNotEmpty(Object o) {
        return !isEmpty(o);
    }

    public static boolean isNotBlank(Object o) {
        return !isBlank(o);
    }

    public static boolean isNumber(Object o) {
        if (o == null) {
            return false;
        } else if (o instanceof Number) {
            return true;
        } else if (o instanceof String) {
            String str = (String) o;
            if (str.length() == 0) {
                return false;
            } else if (str.trim().length() == 0) {
                return false;
            } else {
                try {
                    Double.parseDouble(str);
                    return true;
                } catch (NumberFormatException var3) {
                    return false;
                }
            }
        } else {
            return false;
        }
    }

    public static boolean isBlank(Object o) {
        if (o == null) {
            return true;
        } else if (o instanceof String) {
            String str = (String) o;
            return isBlank(str);
        } else {
            return false;
        }
    }

    public static boolean isBlank(String str) {
        if (str != null && str.length() != 0) {
            for (int i = 0; i < str.length(); ++i) {
                if (!Character.isWhitespace(str.charAt(i))) {
                    return false;
                }
            }

            return true;
        } else {
            return true;
        }
    }
}

你可能感兴趣的:(mybatis,mysql,postgresql,sql)