sqlite查询检索所有不是null的行

iro*_*xxx 4 android

美好的一天,我在这里有2个问题:

首先是背景信息.

从android文档中,当查询数据库时,我们必须返回一个名为"_id"的列,以便它可以使用游标适配器.现在在我的实现中,假设我有3列"_id","列A""列B".

所以,如果我的数据库表中有8个输入行,那么A列中的前3行将被填充,而B列中的后5行将被填充.如果我在数据库中查询B列并在我的bindview中使用下面的代码,则游标返回所有行,这将导致前3个条目为null,最后5个项目显示在我的gridview图像中.

这是我的bindView:

@Override
public void bindView(View view, Context context, Cursor cursor) {
     ViewHolder holder = (ViewHolder)view.getTag();
 int columnIndex = cursor.getColumnIndexOrThrow(columnName);
 final String name = cursor.getString(columnIndex);
     while(cursor.moveToNext()){

            if(name != null){
             Log.d(TAG, "string name in gridimageadapter is " + name);

             BitmapFactory.Options options = new BitmapFactory.Options();
             Bitmap bitmap = BitmapFactory.decodeFile(name);

             Bitmap newbitmap = Bitmap.createScaledBitmap(bitmap, 200, 200, false);
             if(holder.image != null){
                 holder.image.setImageBitmap(newbitmap); 
             }
             bitmap.recycle();

            }
     }
}
Run Code Online (Sandbox Code Playgroud)

所以我的问题是:

  1. 如何编写sqlite查询以返回行不为空的列?我目前的实施是:

    public Cursor retrieveTag(String tag){

        String[] condition = {KEY_ID,tag};
    Cursor cursor = db.query(DATABASE_TABLE, condition, null, null, null, null, null);      
        return cursor;
    }
    
    Run Code Online (Sandbox Code Playgroud)
  2. 从BindView代码,如果我使用这样的条件

    if(!name.equals(null)||!name.equals("")){}

我得到一个NullPointerException.为什么会这样?..这是测试Strings的正确方法吗?

希望我的问题清楚,任何帮助将不胜感激.谢谢.

kot*_*oti 7

通过使用Sql查询,您可以管理没有空值的数据,请参阅下面的代码.

Cursor c=db.rawQuery("Select columnB from tablename where columnB IS NOT NULL");
Run Code Online (Sandbox Code Playgroud)

  • 我迟到但他可以帮助某人,mDatabase.query(TABLE_NAME,null,COLUMN_1 +"IS NOT NULL",null,null,null,null); (8认同)