之前簡單的總結了一下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(下)