我试图以String数组的形式从SQLite数据库中获取数据。
在我的活动:
中public class CreateTagActivity extends Activity {
ListView tagList;
DBFunctions db;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_create_tag);
tagList=(ListView)findViewById(R.id.list_of_tags);
db=new DBFunctions(CreateTagActivity.this);
String[] tagsLists=db.getAllTag();
ArrayAdapter adapter=new ArrayAdapter(CreateTagActivity.this,android.R.layout.simple_list_item_1,tagsLists);
tagList.setAdapter(adapter);
}
}
在我的数据库文件:
中public class DBFunctions extends SQLiteOpenHelper {
private static final String DATABASE_NAME="maindb";
private static final int VERSION=1;
private static final String event_tags="CREATE TABLE "+TABLE_TAGS+"(_id INTEGER PRIMARY KEY AUTOINCREMENT,tag TEXT)";
private final Context context;
public DBFunctions(Context context) {
super(context, DATABASE_NAME, null, VERSION);
this.context=context;
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(event_tags);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS "+event_tags);
onCreate(db);
}
public long insertTag(String tag)
{
SQLiteDatabase db=this.getWritableDatabase();
ContentValues values=new ContentValues();
values.put("tag",tag);
long id=db.insert(TABLE_TAGS,null,values);
return id;
}
public String[] getAllTag()
{
SQLiteDatabase db=this.getWritableDatabase();
String[] columns={"tag"};
Cursor cursor=db.query(TABLE_TAGS,columns,null,null,null,null,null);
int length=cursor.getCount();
String[] value=new String[length];
while(cursor.moveToNext())
{
int i=0;
int index=cursor.getColumnIndex("tag");
value[i]=cursor.getString(index);
i++;
}
return value;
}
}
然后我在tagsList中收到NullPointerException
错误。
这是错误日志:
09-17 11:17:03.695 3084-3084/? E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: pack.proj PID: 3084
java.lang.NullPointerException
at android.widget.ArrayAdapter.createViewFromResource(ArrayAdapter.java:394)
at android.widget.ArrayAdapter.getView(ArrayAdapter.java:362)
at android.widget.AbsListView.obtainView(AbsListView.java:2255)
at android.widget.ListView.measureHeightOfChildren(ListView.java:1263)
at android.widget.ListView.onMeasure(ListView.java:1175)
at android.view.View.measure(View.java:16540)
请帮我解决这个问题。 感谢。
答案 0 :(得分:2)
int i=0;
在每次循环迭代中,将索引重置为零。数组中的所有其他索引保持为null
。
NPE是由提供给null
的数组中的ArrayAdapter
项引起的。
要解决此问题,请将int i=0
移到while
循环之外。