Android數據存儲之SQlite(上)

之前簡單的總結了一下Android開發中SharedPreferences的使用,我覺得并不是很難,有了解Java鍵值對相關知識的人都可以輕松使用。

接下來想說一下Android的另一個存儲工具,也就是最常用功能最強大的Android數據庫SQlite。

Sqlite是什么我就不多廢話,大家不妨去百度一下,很多資料。我想簡單的總結一下我是如何在實際開發過程中使用Sqlite的。(由于一開始不知道Greendao框架,所以直接是用的手寫SQL語句。)

提到SQLite 就不能不說一下SQLiteOpenHelper這個類。 這個類是Android平臺提供給我們一個數據庫輔助類來創建或打開數據庫,有興趣的可以閱讀一下這個類的源碼。

那么我們該如何使用這個類呢?

首先 我們可以創建一個自己的DBHelpr類,用來繼承SQLiteOpenHelper,然后重寫它的onCreate()和onUpgrade()方法,具體代碼如下:

public class DBHelper extends SQLiteOpenHelper {

    /**
     * 登錄人員表.
     */
    public static final String TABLE_LoginMan_NAME = "LoginMan";
    /**
     * 登陸人員 sql語句.
     */
    private String sql_create_LoginMan = "CREATE TABLE IF NOT EXISTS " +
            TABLE_LoginMan_NAME +
            "(loginId VARCHAR PRIMARY KEY ," +
            "loginName VARCHAR," +
            "password VARCHAR," +
            "flag VARCHAR," +
            "line VARCHAR)";
    
    public DBHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    
    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL(sql_create_LoginMan);
    }
    
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
}

這樣我們就有了數據庫和數據表,但是更重要的是需要操作數據庫,也就是傳統的“增刪改查”的操作。對于這類操作,我們可以另外建一個類,名字就叫DBManager。在DBManager中,我們需要實例化DBhelper,然后寫一些“增刪改查”的Sql語句。具體代碼如下:

public class DBManager {
    private DBHelper helper;
    private SQLiteDatabase db;

    public DBManager(Context context) {
        helper = new DBHelper(context);
    }

     /**
         * add LoginMan
         *
         * @param loginMen
         */
        public void addLoginMan(List<LoginMan> loginMen) {
            try {
                ContentValues values = new ContentValues();
                for (LoginMan loginMan : loginMen) {
                    db = helper.getWritableDatabase();
                    values.put("loginId", loginMan.getLoginId());
                    values.put("loginName", loginMan.getLogin_name());
                    values.put("password", loginMan.getPassword());
                    values.put("flag", loginMan.getFlag());
                    values.put("line", loginMan.getLine());
                    db.insert(DBHelper.TABLE_LoginMan_NAME, null, values);
                    db.close();
                }
            } finally {
                //            db.endTransaction();//結束事物
            }
        }
}

這樣 我們就可以直接操作實體類,然后調用DBManager中的addLoginMan來增加登陸人員了。 由于我項目中“刪改查”的代碼是根據自己的需求單獨寫的,不具有參考意義,這里就不放出來了。大家感興趣的話可以參考Android SQLite詳解這篇文章。

SQLite的基本使用方法就先總結到這里,下一篇打算總結一下如何使用開源框架來操作數據庫(greendao)
Android數據存儲之SQlite(下)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容