上次我們說了part1中的File的操作,今天我們來說一下SQLite有關的內容,首先還是看一下一張:
相信看過part1部分的人都知道了,這代表的含義,開啟或者建立一個資料庫的方法,傳回值是一個SQLiteDatabase的類,這個等會仔細說;再來說說這個方法的參數,看看下面的圖:
第一個參數是資料庫的名稱,第二個是操作的模式,第三個參數是是一個可選的factory類,當進行查詢操作的時候就會執行個體化一個cursor子類,當使用null時就代表使用預設的factory。
我們知道,肯定是通過這個方法返回的SQLIiteDatabase進行後續的資料庫操作,我們再來看以下SQLiteDatabase這個類,再看之前,我們通過官方文檔知道他是包含在
android.datebase.sqlite這個包中,對這個包,文檔有如下說明:
這個包包含了QLite資料庫的管理類,可以應用於管理自己的私人資料庫。應用程式可以使用這些類管理私人資料庫。如果建立了一個Content Provider,你可能不得不去使用這些類來建立和管理自己的資料庫來儲存內容。可以查看有關於Content Providers來學習實現一個content provider的好處。可以查看位於SDK中NotePad樣本程式的NotePadProvider類來作為學習content provider的例子,Android搭載SQLite的版本是3.4.0.
如果你是處理來自於一個provider的資料,你將不使用這些SQLite類,而是使用一般的android.database類來代替。
Android發布了一個sqlite3資料庫的工具,位於SDK中的tools目錄,你可以通過再終端上輸入sqlite3來使用這個工具在裝置上瀏覽或者是使用SQL命令。
下面來看看這個包中包含的內容:
有如下介面:
有如下類:
重點是上面的SQLiteCursor類和SQLiteDatabae類,以及一個提供了更加簡潔功能的類SQLiteOpenHelper類。當然還有以上的第二個介面SQLiteDatebase.CursorFactory,這個是剛剛上面說的方法的第二個參數。
SQLiteDatabase常用的方法無非就是開啟或者建立資料庫,查詢,插入例句等,但是還有一個比較重要的方法就是execSQL(String),這個方法是允許我們執行SQL命令的,Andeoid提供了比較簡便的方法是我們易於操作資料庫,但也提供了這種方法使得我們可以使用SQL命令語句。
這裡對這兩種方法各舉一個例子,相信大家就比較熟悉了,我們舉例要在某一個資料庫中插入一條記錄:
方法一:使用SQLiteDatabase的insert方法: www.2cto.com
private void insert(SQLiteDatabase db) {
ContentValues conval = new ContentValues();
conval.put("first_field", value);
db.insert(table, null, conval);
}
private void insert(SQLiteDatabase db) {
ContentValues conval = new ContentValues();
conval.put("first_field", value);
db.insert(table, null, conval);
}這樣就完成了在db資料庫的table表中插入一條記錄,並且該記錄的第一個域的值為value;
方法二:使用execSQL()方法:
首先要構建這樣一條SQL居於,然後將其作為execSQL()的參數進行執行該函數:
private void insert(SQLiteDatabase db) {
String sql = "insert into table(first_field) values("value")";
db.execSQL(sql);
}
private void insert(SQLiteDatabase db) {
String sql = "insert into table(first_field) values("value")";
db.execSQL(sql);
} 其他的一些操作都比較類似,就不一一列舉了。
接下來就是SQLiteOpenHelper類,這是SQLiteDatabase的一個協助類,用來管理資料庫的建立和版本更新的。一般的用法就是定一個類繼承它,並實現它的兩個抽象的方法onCreate()和onUpgrade()。例如:
class ExampleHelper extends SQLiteOpenHelper{
private static final String CREATE = "create table example(id integer, second text)";
private SQLiteDatabase db;
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
摘自 chenlong12580的專欄