Android如何使用SQLiteOpenHelper

 1.SQLiteOpenHelper

  SQliteOpenHelper是一個抽象類,來管理數據庫的創建和版本的管理。要使用它必須實現它的nCreate(SQLiteDatabase),onUpgrade(SQLiteDatabase, int, int)方法

  onCreate:當數據庫第一次被建立的時候被執行,例如創建表,初始化數據等。

  onUpgrade:當數據庫需要被更新的時候執行,例如刪除久表,創建新表。

  2.實現代碼

package xqh.utils;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;

public class DBHelper extends SQLiteOpenHelper {

    //數據庫版本
    private static final int VERSION = 1;
    //新建一個表
    String sql = "create table if not exists TestUsers"+
    "(id int primary key,name varchar,sex varchar)";
   
    public DBHelper(Context context, String name, CursorFactory factory,
            int version) {
        super(context, name, factory, version);
    }

    public DBHelper(Context context,String name,int version){
        this(context,name,null,version);
    }
   
    public DBHelper(Context context,String name){
        this(context,name,VERSION);
    }
   
    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL(sql);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
       
    }
   
}

 

  3.SQLite的使用

  Android提供瞭一個名為SQLiteDatabase的類,它封裝瞭一些操作數據庫的API。使用它能實現基本的CRUD操作,通過getWritableDatabase()和getReadableDatabase()可以獲取數據庫實例。

  4.實現代碼

package xqh.sqlite;

import xqh.utils.DBHelper;
import android.app.Activity;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.widget.Button;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;;

public class TestSQLite extends Activity {

    Button textBtn = null;
    Button btnCreateDb = null;
    Button btnCreateTb = null;
    Button btnInsert = null;
    Button btnUpdate = null;
    Button btnDelete = null;
    DBHelper dbHelper = null;
    SQLiteDatabase db = null;
   
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        setContentView(R.layout.sqlitetest);
       
        OpenDb();
       
        textBtn = (Button)findViewById(R.id.btnHeader);
        textBtn.setFocusable(true);
       
//        btnCreateDb = (Button)findViewById(R.id.btnCreateDb);
//        btnCreateDb.setOnClickListener(createDbListener);
//       
//        btnCreateTb = (Button)findViewById(R.id.btnCreateTb);
//        btnCreateTb.setOnClickListener(createTbListener);
       
        btnInsert = (Button)findViewById(R.id.btnInsert);
        btnInsert.setOnClickListener(insertTbListener);
       
        btnUpdate = (Button)findViewById(R.id.btnUpdate);
        btnUpdate.setOnClickListener(updateTbListener);
       
        btnDelete = (Button)findViewById(R.id.btnDelete);
        btnDelete.setOnClickListener(deleteTbListener);

    }
   
    public OnClickListener deleteTbListener = new OnClickListener() {
        public void onClick(View v) {
            DeleteTb();
        }
    };
   
    public OnClickListener updateTbListener = new OnClickListener() {
        public void onClick(View v) {
            UpdateTb();
        }
    };
   
    public OnClickListener insertTbListener = new OnClickListener() {
        public void onClick(View v) {
            InsertTb();
        }
    };
   
//    public OnClickListener createDbListener = new OnClickListener() {
//        public void onClick(View v) {
//            CreateDatabase("TestDb01");
//        }
//    };

//    public OnClickListener createTbListener = new OnClickListener() {
//        public void onClick(View v) {
//            CreateTable();
//        }
//    };
   
//    /**
//     * 新建一個數據庫
//     * @param dbName
//     * @return
//     */
//    public SQLiteDatabase CreateDatabase(String dbName){
//        dbHelper = new DBHelper(this, dbName);
//        return dbHelper.getWritableDatabase();
//    }
   
    /**
     * 新建一個表
     * @param db
     */
    public void CreateTable(){
        db = dbHelper.getWritableDatabase();
        String sql = "create table if not exists TestUsers"+
                        "(id int primary key,name varchar,sex varchar)";
        try {
            db.execSQL(sql);
        } catch (SQLException e) {
            Log.i("err", "create table failed");
        }
    }
   
    /**
     * 插入數據 www.aiwalls.com
     */
    public void InsertTb(){
        db = dbHelper.getWritableDatabase();
        String sql = "insert into TestUsers (id,name,sex) values (2,'hongguang','men')";
        try {
            db.execSQL(sql);
        } catch (SQLException e) {
            Log.i("err", "insert failed");
        }
    }
   
    /**
     * 更新數據
     */
    public void UpdateTb() {
        db = dbHelper.getWritableDatabase();
        String sql = "Update TestUsers set name = 'anhong',sex = 'men' where id = 2";
        try {
            db.execSQL(sql);
        } catch (SQLException e) {
            Log.i("err", "update failed");
        }
    }
   
    /**
     * 刪除數據
     */
    public void DeleteTb(){
        db = dbHelper.getWritableDatabase();
        String sql = "delete from TestUsers where id = 2";
        try {
            db.execSQL(sql);
        } catch (SQLException e) {
            Log.i("err", "delete failed");
        }
    }
   
    /**
     * 打開數據庫
     */
    public void OpenDb(){
        dbHelper = new DBHelper(this, "TestDb01");
        db = dbHelper.getWritableDatabase();
    }
   
    /**
     * 關閉數據庫
     */
    public void CloseDb(){
        dbHelper.close();
    }
   
    @Override
    protected void onDestroy() {
        super.onDestroy();
        if(db!=null){
            db.close();
        }
        if(dbHelper!=null){
            dbHelper.close();
        }
    }
   
}

 

  5.一些SQLite操作命令

  5.1 adb shell 進入命令模式

  5.2 cd 文件名 進入文件

  5.3 ls或ls -l 查看目錄下的文件

  5.4 sqlite3 數據庫名 進入數據庫

  5.5 .schema 查看數據庫下的信息

  5.6 ctrl+d 退出sqlite模式

  6.測試截圖

 

 

SQLiteDatabase是Android SDK中操作數據庫的核心類之一。使用SQLiteDatabase可以打開數據庫,也可以對數據庫進行操作。然而為瞭數據庫升級的需要以及使用更方便,往往使用SQLiteOpenHelper的子類來完成創建、打開數據庫及各種數據庫操作。
     SQLiteOpenHelper是個抽象類,在該類中有如下兩個抽象方法,SQLiteOpenHelper的子類必須實現這兩個方法。
     public abstract void onCreate(SQLiteDatabase db);
     public abstract void onUpdate(SQLiteDatabase db,int oldVersion,int newVersion);
     SQLiteOpenHelper會自動檢測數據庫文件是否存在。如果存在,會打開這個數據庫,在這種情況下就不會調用onCreate()方法。如果數據庫文件不存在,SQLiteOpenHelper首先會創建一個數據庫文件,然後打開這個數據庫,最後調用onCreate()方法。因此,onCreate()方法一般用來在新創建的數據庫中建立表、視圖等數據庫組建。也就是說oncreate()方法在數據庫文件第一次創建時調用。
    先看看SQLiteOpenHelper類的構造方法再解釋onUpdate()方法何時會被調用。
    public SQLiteOpenHelper(Context context,String name,CursorFactory factory,int version);
    其中name參數表示數據庫文件名(不包括文件路徑),SQLiteOpenHelper會根據這個文件名創建數據庫文件。version表示數據庫的版本號。如果當前傳入的數據庫版本號比上次創建或升級的版本號高,SQLiteOpenHelper就會調用onUpdate()方法。也就是說,當數據庫第一次創建時會有一個初始的版本號。當需要對數據庫中的表、視圖等組建升級時可以增大版本號,再重新創建它們。現在總結一下oncreate()和onUpdate()調用過程。
    1.如果數據庫文件不存在,SQLiteOpenHelper在自動創建數據庫後會調用oncreate()方法,在該方法中一般需要創建表、視圖等組件。在創建前數據庫一般是空的,因此不需要先刪除數據庫中相關的組件。
    2.如果數據庫文件存在,並且當前版本號高於上次創建或升級的版本號,SQLiteOpenHelper會調用onUpdate()方法,調用該方法後會更新數據庫的版本號。在onupdate()方法中除瞭創建表、視圖等組件外,還需要先刪除這些相關的組件,因此,在調用onupdate()方法前,數據庫是存在的,裡面還原許多數據庫組建。
     綜合上述兩點,可以得出一個結論。如果數據庫文件不存在,隻有oncreate()被調用(該方法在創建數據庫時被調用一次)。如果數據庫文件存在,會調用onupdate()方法升級數據庫,並更新版本號。

 
摘自 wangjia55的專欄

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。