個人解讀Activity之四-Part2-SQLite

來源:互聯網
上載者:User

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.