4

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

首先是背景资料。

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

所以如果我的数据库表中有 8 个条目行,其中 A 列中的第 3 行被填充,B 列中接下来的 5 行被填充。如果我在数据库中查询 B 列并在我的 bindview 中使用下面的代码,则光标返回所有行,这将导致前 3 个条目为空,最后 5 个项目显示在我的图像网格视图中。

这是我的绑定视图:

@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();

            }
     }
}

所以我的问题是:

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

    公共游标检索标签(字符串标签){

        String[] condition = {KEY_ID,tag};
    Cursor cursor = db.query(DATABASE_TABLE, condition, null, null, null, null, null);      
        return cursor;
    }
    
  2. 从 BindView 代码中,如果我使用这种条件,例如

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

我得到一个 NullPointerException 。为什么会这样?...这是测试字符串的正确方法对吗?...

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

4

1 回答 1

7

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

Cursor c=db.rawQuery("Select columnB from tablename where columnB IS NOT NULL");
于 2012-08-11T13:03:47.283 回答