美好的一天,我在这里有两个问题:
首先是背景信息。
从 android 文档中,查询数据库时,我们必须返回名称为“_id”的列才能使用游标适配器。现在在我的实现中,假设我有 3 列“_id”、“A 列”、“B 列”。
因此,如果我的数据库表中有 8 个条目行,其中 A 列中的前 3 行已填充,B 列中的下 5 行已填充。如果我查询数据库中的 B 列并在我的绑定(bind) View 中使用下面的代码,光标将返回所有行,这将导致前 3 个条目为空,最后 5 个项目显示在我的图像网格 View 中。
这是我的绑定(bind) View :
@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();
}
}
}
所以我的问题是:
公共(public)光标检索标签(字符串标签){
String[] condition = {KEY_ID,tag};
Cursor cursor = db.query(DATABASE_TABLE, condition, null, null, null, null, null);
return cursor;
}
if( !name.equals(null) || !name.equals("")){
我得到了一个 NullPointerException 异常。为什么会这样?.. 这是测试字符串的正确方法吗?..
希望我的问题很清楚,任何帮助将不胜感激。谢谢你。
最佳答案
通过使用 Sql 查询,您可以管理没有空值的数据,请参见以下代码。
Cursor c=db.rawQuery("Select columnB from tablename where columnB IS NOT NULL");