美文网首页
GreenDao简单快速入门

GreenDao简单快速入门

作者: Sakumi | 来源:发表于2019-05-17 18:00 被阅读0次

之前一直使用SQLite写数据库,前几日用过GreenDao后,相见恨晚。对比的感受就是,SQLite建表,增删改查都需要写很多代码,开发效率低下,并且存取的效率也较低,相比之下,GreenDao建表、使用都很方便,且效率很高,插入和更新的速度都是SQLite的2倍,GreenDao本身不到100k,占用内存也很小。
接下来,我们就来看看,GreenDao到底如何使用。
首先,我们要在项目中集成该框架。在Project : build.gradle中添加仓库和插件。

buildscript {
    
    repositories {
        google()
        jcenter()
        mavenCentral() // 设置maven仓库
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.4.1'
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' // 增加GreenDao插件

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

然后在Module :build.gradle中增加依赖

apply plugin: 'org.greenrobot.greendao' // 应用插件
dependencies {
    implementation fileTree(include: ['*.jar'], dir: 'libs')
    //省略其他不相关依赖库...
    implementation 'org.greenrobot:greendao:3.2.2'// 添加依赖库
    implementation 'net.zetetic:android-database-sqlcipher:3.5.6'//加密库依赖,可选
}

继续在Module :build.gradle中设置数据库属性

greendao {
    schemaVersion 1 //数据库版本号
    daoPackage 'com.example.pax.printer.db.dao'// 设置DaoMaster、DaoSession、Dao 包名
    targetGenDir 'src/main/java'//设置DaoMaster、DaoSession、Dao目录
}

完成以上配置后,同步工程。接下来,我们就开始具体使用GreenDao。先写一个实体类,TransData.java

@Entity
public class TransData {
    @Id
    private Long id;
    private String transType;
    private String cardType;
    private String amount;
    private String traceNo;
    private String dateTime;

    //生成getter、setter函数,我这边就省略了
}

这边我们用到两个注解,@Entity 表明这个实体类会在数据库中生成一个与之相对应的表,@Id 对应数据表中的 Id 字段。
写好实体类后,我们编译下工程,如果配置成功,就会在我们刚刚设置的目录下生成这些文件:


在Application类中初始化GreenDao:

public class FinancialApplication extends MultiDexApplication{
    private static FinancialApplication mApp;
    private DaoSession daoSession;

    @Override
    public void onCreate() {
        super.onCreate();
        FinancialApplication.mApp = this;
        initGreenDao();
    }

    public static FinancialApplication getApp() {
        return mApp;
    }

    private void initGreenDao(){
        DaoMaster.DevOpenHelper openHelper = new DaoMaster.DevOpenHelper(this, "trans_data.db");
        SQLiteDatabase sqLiteDatabase = openHelper.getWritableDatabase();
        DaoMaster master = new DaoMaster(sqLiteDatabase);
        daoSession = master.newSession();
    }

    public DaoSession getDaoSession() {
        return daoSession;
    }
}

获取TransDataDao:

    DaoSession daoSession = FinancialApplication.getApp().getDaoSession();
    private TransDataDao dataDao;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_new_record);
        dataDao = daoSession.getTransDataDao();

    }

数据库的增删改查:

 public void onSaveClick(View view){
        TransData transData = new TransData();
        transData.setDateTime(getDateTime());
        transData.setTransType(transType.getText().toString());
        transData.setAmount(amount.getText().toString());
        transData.setCardType(cardType.getText().toString());
        transData.setTraceNo(transNo.getText().toString());

        if(recordId > 0){
            transData.setId(recordId);
            dataDao.update(transData);//更新数据,使用这个方法记得要传id,不然会出错
        }else {
            dataDao.insertOrReplace(transData);//增加数据,使用insert(T entity)也一样的
        }
    }

    public void onDelClick(View view){
        dataDao.deleteByKey(recordId);//根据id删除数据,还有别的方法,可以自己试一试
    }

    private TransData getTransData(long id){
        return dataDao.loadByRowId(id);//根据id查询数据,查询全部的话用loadAll()
    }

到这里,GreenDao的基础使用就介绍完啦。

相关文章

网友评论

      本文标题:GreenDao简单快速入门

      本文链接:https://www.haomeiwen.com/subject/zjkoaqtx.html