sqlite查询检索所有不是null的行
发布时间:2020-12-12 18:55:37 所属栏目:百科 来源:网络整理
导读:美好的一天,我在这里有2个问题: 首先是背景信息. 从android文档中,当查询数据库时,我们必须返回一个名为“_id”的列,以便它可以使用游标适配器.现在在我的实现中,假设我有3列“_id”,“列A”“列B”. 所以,如果我的数据库表中有8个输入行,那么A列中的前3行
美好的一天,我在这里有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,false); if(holder.image != null){ holder.image.setImageBitmap(newbitmap); } bitmap.recycle(); } } } 所以我的问题是: >如何编写sqlite查询以返回行不为空的列?我目前的实施是: public Cursor retrieveTag(String tag){ String[] condition = {KEY_ID,tag}; Cursor cursor = db.query(DATABASE_TABLE,condition,null,null); return cursor; } >从BindView代码,如果我使用这种情况 if(!name.equals(null)||!name.equals(“”)){ 我得到一个NullPointerException.为什么会这样?..这是测试Strings的正确方法吗? 希望我的问题清楚,任何帮助将不胜感激.谢谢. 解决方法通过使用Sql查询,您可以管理没有空值的数据,请参阅下面的代码.Cursor c=db.rawQuery("Select columnB from tablename where columnB IS NOT NULL"); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |