Android SQLite数据存储的通用设计

SQLite用于存储一些数据量较多,结构比较复杂情况,使用的时候只需要实现SQLiteOpenHelper,在onCreate创建数据表,onUpgrade做升级处理

通过Helper实例对DB进行数据处理,例如,database = dbHelper.getWritableDatabase();  获取DB对象进行插入,更新,删除操作,dbHelper.getReadableDatabase()

进行数据查询,在此不必多说,这样实现一个数据库并不复杂,但是对不同对象存储操作还需要分别各自去自己实现,比较麻烦,能不能用一种通用设计实现呢?


其实存入DB内的数据都是要分隔成基本String, int , long, double等,在android中可以使用数据集ContentValues进行存储,ContentValues可以存储基本类型,类似于Map

ContentValues是可直接用于SQLiteDatabase,ContentProvider中进行批量处理,这是android为此设计的,在SQLiteDatabase我们使用ContentValues是非常简单的。

好了下面我们需要对通用数据操作定义一种规则,我们只需要传入tableName,whereArgs(筛选条件),ContentValues即可实现insert, quere,delete,update功能


接口定义如下:

public interface IDBDelegate {

    public boolean insertData(String tableName,String nullColumnHack,ContentValues values);

    public boolean deleteData(String tableName,String whereClause, String[] whereArgs);

    public boolean updateData(String tableName,ContentValues values, String whereClause, String[] whereArgs);

    //查询单条数据集
    public Map<String, String> getRowData(String tableName, String selection, String[] selectionArgs);

    //查询多条数据集
    public List<Map<String, String>> getListData(String tableName, String selection, String[] selectionArgs);

}


实现类

public class DBDelegateImpl implements IDBDelegate{

    private final Object obj=new Object();
    private DBHelper dbHelper=null;

    public DBDelegateImpl(Context context) {
        dbHelper=DBHelper.getInstance(context);
    }

    @Override
    public boolean insertData(String tableName,  String nullColumnHack,ContentValues values) {
        synchronized (obj) {
            boolean flag = false;
            SQLiteDatabase database = null;
            long id = -1;
            try {
                database = dbHelper.getWritableDatabase();
                id = database.insert(tableName, nullColumnHack, values);
                flag = (id != -1);
            } catch (SQLException e) {
                e.printStackTrace();
            } finally {
       
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值