GreenDao(2)--使用

上一篇讲了GreenDao的配置,本篇着重于API的各种使用,并附上Demo。

类的关系

大家还记得上一篇讲到的代码自动生成的四个类,DaoMaster,DaoSession,Dao,User,排除最后一个User实体类不说,其他三个的关系应该是非常明确的。

类图

从图上看出,得到User对象的步骤。其中还有些细节需要说明。

获取DaoMaster

用过数据库的程序圆都清楚,我们需要DaoSession对象来进行对数据库的增删改查。

DaoMaster中有newSession()的方法可以帮我们实现。

所以我们应该先实例化DaoMaster,具体代码是

public DaoMaster(SQLiteDatabase db) {
    super(db, SCHEMA_VERSION);
    registerDaoClass(UserDao.class);
}

噢,需要一个SQLiteDatabase实例,请拼命想一想怎么获取一个SQLiteDatabase实例?

没错,通过SQLiteOpenHelper,再仔细看一下DaoMaster,好像已经提供了抽象类OpenHelper继承了SQLiteOpenHelper

Cool!

可以获取DevOpenHelper,具体代码是

     /**
     * WARNING: Drops all table on Upgrade! Use only during development.
     */
    public static class DevOpenHelper extends OpenHelper {
        public DevOpenHelper(Context context, String name, CursorFactory factory) {
            super(context, name, factory);
        }

        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            Log.i("greenDAO", "Upgrading schema from version " + oldVersion + " to " + newVersion + " by dropping all tables");
            dropAllTables(db, true);
            onCreate(db);
        }
    }

先不管警告的注释(当数据库升级的时候会删除所有表,仅限于开发时使用)。

只要简单两行代码

 DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(context, DB_NAME, null);
DaoMaster daoMaster = new DaoMaster(mHelper.getReadableDatabase());
//也可以使用mHelper.getWritableDatabase();

注意:getReadabledatabase()与getWritableDatabase()其实返回的实例都是一样的,只是当内存空间不足的时候,就不能继续写入数据,更为重要的是,它们都是耗时耗时耗时操作!更为详细的解释

获取DaoSession

接着,我们来获取DaoSession

DaoSession daoSession = daoMaster.newSession();
//异步查询,异步查询,异步查询
AsyncSession asyncSession = daoSession.startAsyncSession();

够简单吗?获得DaoSession后可以干什么?其实增删改查的基本功能已经齐全。
只是有三个缺点:

  • 颗粒度太大
  • API不是很方便
  • 官网注释说只是用于快捷操作

所以UserDao登场吧

获取UserDao

UserDao userDao = daoSession.getUserDao();

好了,下面就可以随心所欲地操作数据库了。

操作数据库

/**
 * 插入一个User对象
 *
 * @param user
 * @return 插入对象的列id
 */
public long insert(User user) {
    UserDao userDao = getUserDao();
    return userDao.insert(user);
}

查查查***重点

具体方法有

  • queryXXX(...),指明各种条件
  • 使用QueryBuilder(单次查询),Query(多次查询)
  • 其他等

这里着重讲QueryBuilderQuery,个人用得非常顺手,因为自己对SQL语句并不喜欢,so...

看一个简单例子

/**
 * 通过id取得用户。此处使用QueryBuider,并没有构造Query
 *
 * @param id
 * @return
 */
public User getUserById(long id) {
    UserDao userDao = getUserDao();
    //获取QueryBuilder
    QueryBuilder qb = userDao.queryBuilder();
    //声明条件,属性在UserDao中已经存在
    qb.where(UserDao.Properties.Id.eq(id));
    //返回唯一数据
    return (User) qb.unique();
}

QueryBuilder只是用来创建Query而已,Query更使用于相同的查询,所以QueryBuilder就不要随便用了。

Quert特点如下

  • Query通过QueryBuilder.build()获取,它是使用Builder模式设计的,支持多次查询多线程查询

      //实际按照要求具体操作
      Query<User> query = userDao.queryBuilder().orderDesc().where().count().build();
      //返回单一结果
      query.unique()
      //返回一个非null的实体。否则就会抛出一个DaoException。
      query.uniqueOrThrow()
      //所有查询都加载到内存
      query.list();
      //实体按照需求加载进入内存。一旦列表中的一个元素被第一次访问,它将被加载同时缓存以便以后使用。必须close。
      query.listLazy();
      //多线程查询,为当前线程获取一个Query实例
      query.forCurrentThread();
    
  • 支持equal,in,between等等一系列比较符

  • Query可重用

先创建如下Query,根据id = 123和age = 10进行查找(示例)

    UserDao userDao = getUserDao();
    QueryBuilder<User> queryBuilder = userDao.queryBuilder().where(UserDao.Properties.Id.eq(123));
    queryBuilder.where(UserDao.Properties.Age.eq(10)).unique();
    Query query = queryBuilder.build();
    query.unique();

下一次同样需要根据id = 321和age = 100来进行查找,就可以

//设置id和age的值
query.setParameter(321, 100);
//返回唯一结果
//query.unique()
//设置多个查找目标
query.setParameter(111, 180);
//返回list
query.list();

注意:当Query没有返回语气结果,故障排查可以设置QueryBuilder.LOG_SQL = true;QueryBuilder.LOG_VALUES = true;,打印出SQL语句

更多高级用法请查看官方API文档

基本原则是根据主键来修改,比较简单的两种情况是

  • 已知主键

直接能用API的都基本上已知主键的

    /**
     * 更新user信息
     *
     * @param newUser 新User,主键必须存在
     */
    public void update(User newUser) {
        UserDao userDao = getUserDao();
        userDao.update(newUser);
    }
  • 未知主键,知道其他值

先根据主键查找(复习查找的知识),再重复情况一

同理,跟改操作基本一致。

   /**
     * 根据主键删除User
     *
     * @param id User的主键Id
     */
    public void deleteUserById(long id) {
        UserDao userDao = getUserDao();
        userDao.deleteByKey(id);
    }

总结

GreenDao给我们简化了编写大量重复代码的步骤,作为轻量级的ORM框架速度飞快,值得深入学习。

GreenDao底层并不保证线程安全,这意味着多线程环境下还需要我们程序圆来控制 ;)

源码戳这里

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容

  • GreenDao 介绍:greenDAO是一个对象关系映射(ORM)的框架,能够提供一个接口通过操作对象的方式去操...
    小董666阅读 732评论 0 1
  • greenDAO greenDAO 是一个将对象映射到 SQLite 数据库中的轻量且快速的 ORM 解决方案。它...
    蕉下孤客阅读 16,093评论 18 104
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,617评论 18 399
  • 1. 什么是greenDao 弄明白greenDao之前我们应该先了解什么是ORM(Object Relation...
    看一季残花落幕阅读 2,501评论 0 4
  • Dijkstra 模板一(map数组模拟邻接表) 处理小图速度相对较快。内存占用较小,对重边优化较差。 模板二(链...
    染微言阅读 540评论 0 0