我有两个按钮,一个向DB添加数据,另一个获取所有数据。表是我的类,其中包含有关表的信息(Table.TABLE_NAME ==" table")。但是光标总是空的。我尝试了这个db.query(Table.TABLE_NAME,null,null,null,null,null,null),它也不起作用。
public void onClick(View v) {
DBHelper dbHelper = new DBHelper(this);
SQLiteDatabase db = dbHelper.getWritableDatabase();
Cursor cursor = null;
switch (v.getId()){
case R.id.btnAdd:
ContentValues contentValues = new ContentValues();
contentValues.put("Name",etName.getText().toString());
contentValues.put("Surname",etSurname.getText().toString());
contentValues.put("Age",etAge.getText().toString());
contentValues.put("City",etCity.getText().toString());
db.insert(Table.TABLE_NAME,null,contentValues);
Log.d(TAG,etName.getText().toString() +" " + etSurname.getText().toString() +" " + etAge.getText().toString()+" " + etCity.getText().toString());
break;
case R.id.btnSearch:
cursor = db.rawQuery("select * from "+Table.TABLE_NAME,null);
break;
}
if (cursor != null) {
if(cursor.moveToFirst()) {
String str;
do {
str = "";
for (String cn : cursor.getColumnNames()) {
str = str.concat(cn + " = " + cursor.getString(cursor.getColumnIndex(cn)) + "; ");
}
} while (cursor.moveToNext());
}
cursor.close();
}else {
Log.d(TAG,"null");
}
db.close();
}
答案 0 :(得分:0)
您的光标始终为null,因为您从未初始化它。 尝试这样的事情:
Cursor cursor = db .query(TABLE_NAME, columns, null, null, null, null, null);
但在你的开关区外面 - 否则就无法到达。
使用调试器,它会告诉您需要知道的实际情况。
您还可以考虑使用https://github.com/square/sqlbrite; 它可以帮助您在各种情况下同步数据。
答案 1 :(得分:0)
使用dbHelper.getReadableDatabase()
从数据库中获取数据。
试试这个:
case R.id.btnSearch:
db = dbHelper.getReadableDatabase();
cursor = db.rawQuery("select * from "+Table.TABLE_NAME,null);
break;