標籤:android sqlite
query()方法實際上是把select語句拆分成了若干個組成部分,然後作為方法的輸入參數:
SQLiteDatabase db = databaseHelper.getWritableDatabase();
Cursor cursor = db.query("person", new String[]{"personid,name,age"}, "name like ?", new String[]{"%傳智%"}, null, null, "personid desc", "1,2");
while (cursor.moveToNext()) {
int personid = cursor.getInt(0); //擷取第一列的值,第一列的索引從0開始
String name = cursor.getString(1);//擷取第二列的值
int age = cursor.getInt(2);//擷取第三列的值
}
cursor.close();
db.close();
上面代碼用於從person表中尋找name欄位含有“傳智”的記錄,匹配的記錄按personid降序排序,對排序後的結果略過第一條記錄,只擷取2條記錄。
query(table, columns, selection, selectionArgs, groupBy, having, orderBy, limit)方法各參數的含義:
table:表名。相當於select語句from關鍵字後面的部分。如果是多表聯集查詢,可以用逗號將兩個表名分開。
columns:要查詢出來的列名。相當於select語句select關鍵字後面的部分。
selection:查詢條件子句,相當於select語句where關鍵字後面的部分,在條件子句允許使用預留位置“?”
selectionArgs:對應於selection語句中預留位置的值,值在數組中的位置與預留位置在語句中的位置必須一致,否則就會有異常。
groupBy:相當於select語句group by關鍵字後面的部分
having:相當於select語句having關鍵字後面的部分
orderBy:相當於select語句order by關鍵字後面的部分,如:personid desc, age asc;
limit:指定位移量和擷取的記錄數,相當於select語句limit關鍵字後面的部分
sqlite 中的query操作