光标是空的

时间:2017-04-25 18:52:59

标签: android android-sqlite android-cursor

我有两个按钮,一个向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();
        }

2 个答案:

答案 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;