本文主要是介绍一起来写个SQLite ORM数据库框架(上),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前言
谈起Android的数据库框架、相信大家一定不会陌生 目前开源的有:
- GreenDao:基于编译时注解 性能较好 但是配置较麻烦
- Ormlite:基于运行时注解 性能一般 配置简单些
- Rleam:貌似不是基于表结构的 性能很好 使用简单 支持json格式 但是不支持sql语句
如果要选一个开源的话 我比较倾向和建议的是GreenDao3.0,但实际上这些我都没用过,只是看过github上面的介绍 前面两个我觉得麻烦 realm不支持sql 感觉不好用
对于第三方库来说 我一贯的思想是能不用就不用,能用轻量级的就不用重量级的,所以我一直没用过View的注解框架 而是在基类里面写这个方法
protected <E extends View> E $(int resId) {return (E) this.findViewById(resId);
}
看过ButterKnife的源码的同学应该知道 它里面也有类似的方法。
SQLiteOpenHelper
这里不得不提一下 Android自带的SQLiteDatabase的帮助类SQLiteOpenHelper,因为我之前和大多数刚学Android数据库的同学一样,用的就是这个,我们来看一下他的实现
public class DBHelper extends SQLiteOpenHelper {public DBHelper(Context context,String name,CursorFactory factory,int version) {super(context, name, factory, version);}@Overridepublic void onCreate(SQLiteDatabase db) {}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
}
构造函数里面可以配置数据库名称和数据库版本,onCreate方法执行创建表的操作,onUpgrade里面做更新操作,那数据库是什么时候创建的呢?我们知道操作数据库的时候一般会执行getWritableDatabase()
获取返回的SQLiteDatabase
,我们来看下它的源码
public SQLiteDatabase getWritableDatabase() {synchronized (this) {return getDatabaseLocked(true);}}//跟进getDatabaseLocked方法private SQLiteDatabase getDatabaseLocked(boolean writable) {......//省略其他判断的代码 if (DEBUG_STRICT_READONLY && !writable) {final String path = mContext.getDatabasePath(mName).getPath();db = SQLiteDatabase.openDatabase(path, mFactory,SQLiteDatabase.OPEN_READONLY, mErrorHandler);} else {db = mContext.openOrCreateDatabase(mName, mEnableWriteAheadLogging ?Context.MODE_ENABLE_WRITE_AHEAD_LOGGING : 0,mFactory, mErrorHandler);}......}
它源码里面主要是一个线程安全锁和读写以及是否打开创建的判断,最终会执行mContext.openOrCreateDatabase
其实还是调用的SQLiteDatabase.openDatabase(..)
创建数据库,SQLiteDatabase这个类里面就是我们常用的开关数据库、事务、增删改查等操作,具体的数据库操作函数是通过JNI调用C代码执行的 而且是本地数据库 所以Android原生的SQLiteDatabase性能还是很好的。以上只是简单分析 想深入了解的朋友可以看这篇博客SQLiteOpenHelper/SQLiteDatabase/Cursor源码解析
ok,下面来说说SQLiteOpenHelper几点不方便的地方
- 创建的数据库默认是在data/data/packgname/database目录,相对较安全,但是查看需要root权限,我的山寨手机一直root不了 之前看数据库都用的模拟器 很傻啊
- 因为他是基于版本控制的,所以每次更新需要配置version还要在onUpgrade里面写需要更新或者添加的表,这意味着需要重新打包发布,如果数据是动态获取的,表结构是变化的,这样肯定不行
- 最麻烦的就是自己要写大量的sql语句,我最近的项目里面一个实体类有一百多个字段,让我写sql会疯的
自己写一个吧
参考了开源的TigerDB ,写了一个基于SQLite简单的ORM框架—easyDB
https://github.com/1139618418/easyDB
下一章节介绍具体的代码实现
这篇关于一起来写个SQLite ORM数据库框架(上)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!