GreenDao3.0源码分析-Helper

GreenDao3.0系列文章:

GreenDao3.0源码分析-Helper

GreenDao3.0 源码分析-DaoMaster和DaoSeesion

GreenDao3.0 源码分析-Dao层

图片原图可以从github 源码地址 ->GreenDao 文件中 亿图 打开。

GreenDao3.0源码架构图

image.png

上面是我画的GreenDao分层,我们将根据分层逐步分析原理。

GreenDao3.0原理

从图中我们可以看到,其实GreenDao3.0是以Android Sqlite为底层,然后做一些缓存使得大数据的时候能更有效的增删改查。GreenDao最吸引我的:一是对缓存的处理。二就是代码生成。下面我们将一步步对项目源码进行解剖。

GreenDao最底层就是Sqlite 为基础。

工具层:是对Sql语句的处理和Dao配置的解析。

内部类:只要是提供给外层的一些基础类。

 对外层:是对客户端的层面,这一层可以直接进行对实体的增删改查。

GreenDao3.0 Helper类

  我们先从一开始的出口的帮助类流程开始解析,一步一步引导进来是酱紫的顺便。

   DevOpenHelper->OpenHelper->DatabaseOpenHelper->SQLiteOpenHelper

   DevOpenHelper核心代码:

    ![image](http://upload-images.jianshu.io/upload_images/3161886-a1c61c92d22e7ba6?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    他只实现了这个更新的操作,使用这个帮助类,每一次进行版本更新的时候都删除所有的表然后再创建,所以我们每次进行加版本都会导致数据遗失。 

    OpenHelper核心代码:

    ![image](http://upload-images.jianshu.io/upload_images/3161886-c6e6f7979bf03040?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

              ![image](http://upload-images.jianshu.io/upload_images/3161886-af5ed4c64376f709?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    OpenHelper完成了两个功能,一个是建表,一个是传入当前的版本。

    DatabaseOpenHelper核心:

    DatabaseOpenHelper继承自Sqlite帮助类,通过代理模式的思想,进行狸猫换太子般把SQLiteDatabase->扩展成Database。

    ![image](http://upload-images.jianshu.io/upload_images/3161886-adeb08e13735dbb9?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

而StandardDatabase实现了Database接口,Database拥有SQLiteDatabase所有的功能方法,只是替换调用,这个类后面再说。

DatabaseOpenHelper第二个功能是扩展了EncryptedHelper继承于net.sqlcipher.database.SQLiteOpenHelper,当我们需要加密的时候可以使用。

总结一下就是:

DatabaseOpenHelper:主要完成SQLiteDatabase->Database和创建加密帮助类两个功能。

OpenHelper:主要完成建表的功能。

DevOpenHelper:主要处理更新数据库版本的时候,进行删库再处理。开发时候建议不使用此类,可以自己重写处理。

Database

image

上面关系图我们知道,DataBase是GreenDao内的数据库规范接口,StandardDatabase是DataBase的实现,其实就是通过代理模式通过调用SQLiteDatabase完成功能的扩展。

下面我们来说说DataBase各个方法执行的操作:

image

Cursor rawQuery(String sql, String[] selectionArgs):执行查询的Sql语句返回游标。

void execSQL(String sql) throws SQLException:执行无条件Sql语句。

void execSQL(String sql, Object[] bindArgs) throws SQLException:执行有条件Sql语句。

void beginTransaction()、void endTransaction()、void setTransactionSuccessful():数据库事务三个方法。分别是开启、结束、设置成功。

boolean inTransaction():判断是否在一个事务中。

DatabaseStatement compileStatement(String sql):通过有占位符的Sql语句获取一个SQLiteStatement并包装到DatabaseStatement 。

boolean isDbLockedByCurrentThread():如果当前线程持有到数据库的活动连接,则返回true,此方法的名称来自于与数据库有活动连接的时间,意味着该线程在数据库上持有实际锁定。

Object getRawDatabase():获取源数据库,比如现在使用的代理源数据库是Sqlite,就返回SQLiteDatabase。

DatabaseStatement

DatabaseStatement是SQLiteStatement的代理,解决了SQL注入值的问题,因可以复用优化了性能。提供方法如下。

![image](http://upload-images.jianshu.io/upload_images/3161886-344e911e5288a3f8?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

void execute():绑定了值后,执行sql statement语句。

public long simpleQueryForLong():执行一个sql statement语句,返回一个数值。比如:SELECT COUNT(*) FROM table;

public long executeInsert():执行一个sql statement语句,返回一个rowId.常用于插入。

public void clearBindings():清理绑定。

public Object getRawStatement():获取源Stamtement对象,返回被代理的对象。

public void bindXXX(int index, XX value):对应Index绑定相应的基本类型的值。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,071评论 18 399
  • 一、SQLite 1、SQLite介绍 1.1、简介 SQLite是一款轻型的数据库,是遵守ACID的关联式数据库...
    AndroidMaster阅读 6,109评论 0 7
  • 分享 Giovanni Marradi 的歌曲《Shadows》https://www.xiami.com/son...
    彼岸__花阅读 1,117评论 0 0
  • 听到长沙面基的消息我是很激动的~~,我一直想着去认识一些人,但无奈有社恐,大学时候很多次面基的都止于美好的想象之中...
    放羊的小娃娃阅读 1,814评论 3 0
  • 既然是写理财的文章,就来说一说今天发生的一件高兴的事。 上班的时候忽然接到老公电话,说股票中签了,要打钱到股票账户...
    冯陈陈阅读 2,415评论 3 1

友情链接更多精彩内容