個人解讀Activity之四-Part2-SQLite – Android移動開發技術文章_手機開發 Android移動開發教學課程

上次我們說瞭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.aiwalls.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的專欄

發佈留言