天天看點

使用系統api實作資料庫的增、删、改、查

首先要在建立資料庫的同時獲得資料庫對象,即打開資料庫。然後才能對資料庫進行操作,資料庫的操作完成後一定要記得關閉資料庫。如下圖:

注:下面的databasehelper即上圖中的helper

“增”(insert)的完整語句:

sqlitedatabase db = databasehelper.getwritabledatabase();

contentvalues values = newcontentvalues();

values.put("name","傳智播客");

values.put("age", 4);

long rowid = db.insert(“person”,null, values);//添加資料并傳回新添記錄的行号,與主鍵id無關。若無需傳回行号,則“long rowid=”可以不寫。利用行号判斷是否插入成功,如果行号大于等于0,則插入成功,若小于0則插入失敗。

db.close();//關閉資料庫

“删”( delete)的完整語句:

sqlitedatabase db =databasehelper.getwritabledatabase();

int number= db.delete("person","personid<?", new string[]{"2"});//number為影響的行數,如果删除成功值為1,删除失敗值為0。

上面代碼用于從person表中删除personid小于2的記錄。

“改”( update)的完整語句:

values.put(“name”, “傳智播客”);//key為所要修改的字段名,value為所改成的值

int number=db.update("person",values, "personid=?", new string[]{"1"}); //number為影響的行數,如果修改成功其值将大于0.

上面代碼用于把person表中personid等于1的記錄的name字段的值改為“傳智播客”。

update(string table,contentvaluesvalues,string whereclause,string[] whereargs)方法各參數的含義:

table:表名。

values:所要更新的資料。

whereclause:選擇條件。

whereargs:所要修改的資料的id。

“查”( query)的完整語句:

cursor cursor = db.query("person", newstring[]{"personid,name,age"}, "name like ?", newstring[]{"%傳智%"}, null, null, "personiddesc", "1,2");

while (cursor.movetonext()) {

         int personid = cursor.getint(0); //擷取第一列的值,第一列的索引從0開始

        string name = cursor.getstring(1);//擷取第二列的值

        int age = cursor.getint(2);//擷取第三列的值

}

cursor.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關鍵字後面的部分,如:personiddesc, age asc;

limit:指定偏移量和擷取的記錄數,相當于select語句limit關鍵字後面的部分。