Android greenDAO3x数据库框架使用小结

本文总结了Android开发中使用greenDAO3.x框架进行数据库操作的经验。通过注解方式生成实体类,对比2.x版本,3.x更方便易用。介绍了如何创建User类,生成数据库session,以及简单的数据保存。提出了一个用户对应一个数据库的策略,以提高查询效率和简化代码。同时,讨论了数据库版本升级和混淆规则的应用。
摘要由CSDN通过智能技术生成
greenDAO是个很好用的Android数据库框架

https://github.com/greenrobot/greenDAO


导入工程

在Project目录的build.gradle文件中添加

buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.0'
    }
}

在Module目录中的build.gradle文件中添加

apply plugin: 'org.greenrobot.greendao'

dependencies {
    compile 'org.greenrobot:greendao:3.2.0'
}

完成上述动作后,接着给项目配置自动生成创建db代码文件的相关参数。
在Module中配置build.gradle参数

defaultConfig {
        applicationId "demo.app.android.greendao3xdemo"
        versionCode 1
    }
greendao {
    schemaVersion 1
    daoPackage 'demo.app.android.greendao3xdemo.db'
    targetGenDir 'src/main/java'
}


创建表对应实体类和简单的crud

greenDAO 2.x需要创建一个java项目来自动生成表对应的实体类,而3.x可以通过注解的方式来自动生成对应的实体类。
到目前为止,2.x和3.x的生成方式各有优缺点。3.x自动生成的实体类使用起来比2.x便捷,2.x的可以定制内容不同的数据库(多Schema)
不过个人感觉3.x还是比2.x好用很多


一般常见应用中都有用户模块,那么这里创建一个User类演示

package demo.app.android.greendao3xdemo.db.model;

@Entity
public class User {
    @Id private Long id;

    @Property(nameInDb = "USERNAME") private String username;
}

@Entity 建立表和实体的对应关系
@Id 建立表主键和类成员变量关系
@Property 建立表字段和类成员变量关系

之后Build Moudle,会自动生成构造方法、get、set等


此刻Moudle中应该会产生类似如下的目录结构




在具体数据的crud之前,应该预先在全局的applicaiton对象中准备好数据库session对象

public class App extends Application {

    private static App instance;

    private DaoMaster.OpenHelper dbHelper;
    private DaoSession dbSession;

    @Override
    public void onCreate() {
        super.onCreate();
        instance = this;
    }

    public static synchronized App i() {
        return instance;
    }

    public DaoSession getDBSession() {
        if (dbSession != null) {
            dbSession.clear();
        }
        if (dbHelper == null) {
            dbHelper = new DaoMaster.DevOpenHelper(this, "db_user");
            DaoMaster daoMaster = new DaoMaster(dbHelper.getWritableDatabase());
            dbSession = daoMaster.newSession();
        }
        return dbSession;
    }
}


在一切都准备就绪后便可以开始实战。
添加登录界面并且加入登录逻辑(并且将用户保存至数据库)

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值