Greendao 条件查询数据报错 the bind value at index 2 is null

导致报错的方法:

  • xxxDao.queryBuilder().where(xxxDao.Properties.XXX.eq(value).unique()
  • xxxDao.queryBuilder().where(xxxDao.Properties.XXX.notEq(value).unique()

先说下解决方法:就是对以上的方法的调用传入的 value值做空判断。

比如: xxxDao.queryBuilder().where(xxxDao.Properties.XXX.eq(value == null ? "" : value).unique()

或者写一个统一处理的类,类似下面这样,

import org.greenrobot.greendao.Property;import org.greenrobot.greendao.query.WhereCondition;public class CheckNullProperty {    public static WhereCondition eq(Property property, Object value) {        if (value == null) {            value = "";        }        return property.eq(value);    }    ...}

然后这样调用 xxxDao.queryBuilder().where(CheckNullProperty.eq(xxxDao.Properties.XXX, value))


报错的原因是 org.greenrobot.greendao.Property 类方法传入的 valuenull 导致的。

查看 以下.eq(value)的源代码可以知道,当 valuenull 时,返回的 PropertyCondition 的 value 也是 null

/** Creates an "equal ('=')" condition  for this property. */public WhereCondition eq(Object value) {  return new PropertyCondition(this, "=?", value);}
public PropertyCondition(Property property, String op, Object value) {    super(checkValueForType(property, value));    ...}
private static Object checkValueForType(Property property, Object value) {    if (value != null && value.getClass().isArray()) {        throw new DaoException("Illegal value: found array, but simple object required");    }    Class<?> type = property.type;    if (type == Date.class) {        ...    } else if (property.type == boolean.class || property.type == Boolean.class) {        if (value instanceof Boolean) {            return ((Boolean) value) ? 1 : 0;        } else if (value instanceof Number) {           ...        } else if (value instanceof String) {           ...        }    }    return value;}

然后通过 断点 跟踪,发现最后报错的源头 android.database.sqlite.SQLiteProgram

public void bindString(int index, String value) {    if (value == null) {        throw new IllegalArgumentException("the bind value at index " + index + " is null");    }    bind(index, value);}

更多相关文章

  1. Android(安卓)解决方法数 65536 (65k) 限制
  2. android thread Interrupte使用方法
  3. android window.requestWindowFeature()常用方法(转)
  4. Android(安卓)Studio 用 JNI 实现与原生代码通信
  5. android asset中 zip包解压sdcard
  6. android中webviewjs与java的相互调用
  7. Android隐藏标题栏的四种方法
  8. Android(安卓)menu使用
  9. Android(安卓)强制设置横屏或竖屏 设置全屏

随机推荐

  1. Android(安卓)UI开发神兵利器之Android(
  2. android 网络访问-图片处理优秀开源项目
  3. Android(安卓)Handler内存泄露
  4. Android如何从服务器获取图片
  5. Android(安卓)Gradle使用详解
  6. Android(安卓)Studio 错误 com.android.d
  7. android 易忘知识
  8. EditText 相关功能
  9. android里面的USB功能-----Accessory模式
  10. android 系统(13)---Android(安卓)O treble