SQLite 中的query操作
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關鍵字后面的部分