Я хочу использовать запрос выбора для извлечения данных из таблицы. Я нашел метод rawQuery(query, selectionArgs)
класса SQLiteDatabase
для извлечения данных. Но я не знаю, как query
и selectionArgs
следует передать методу rawQuery
?
RawQuery (query, selectionArgs)
Ответ 1
rawQuery("SELECT id, name FROM people WHERE name = ? AND id = ?", new String[] {"David", "2"});
Вы передаете массив строк с равным количеством элементов, так как у вас есть??
Ответ 2
Возможно, это поможет вам
Cursor c = db.rawQuery("query",null);
int id[] = new int[c.getCount()];
int i = 0;
if (c.getCount() > 0)
{
c.moveToFirst();
do {
id[i] = c.getInt(c.getColumnIndex("field_name"));
i++;
} while (c.moveToNext());
c.close();
}
Ответ 3
Один пример rawQuery - db.rawQuery("select * from table where column = ?",new String[]{"data"});
Ответ 4
см. ниже код, который может вам помочь.
String q = "SELECT * FROM customer";
Cursor mCursor = mDb.rawQuery(q, null);
или
String q = "SELECT * FROM customer WHERE _id = " + customerDbId ;
Cursor mCursor = mDb.rawQuery(q, null);
Ответ 5
String mQuery = "SELECT Name,Family From tblName";
Cursor mCur = db.rawQuery(mQuery, new String[]{});
mCur.moveToFirst();
while ( !mCur.isAfterLast()) {
String name= mCur.getString(mCur.getColumnIndex("Name"));
String family= mCur.getString(mCur.getColumnIndex("Family"));
mCur.moveToNext();
}
Имя и фамилия - ваш результат
Ответ 6
Для полноты и правильного управления ресурсами:
ICursor cursor = null;
try
{
cursor = db.RawQuery("SELECT * FROM " + RECORDS_TABLE + " WHERE " + RECORD_ID + "=?", new String[] { id + "" });
if (cursor.Count > 0)
{
cursor.MoveToFirst();
}
return GetRecordFromCursor(cursor); // Copy cursor props to custom obj
}
finally // IMPORTANT !!! Ensure cursor is not left hanging around ...
{
if(cursor != null)
cursor.Close();
}