之前简单的总结了一下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 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(下)