当前位置: 首页>资讯 >

Android数据库greenDAO配置与使用介绍

来源: 脚本之家 | 时间: 2023-07-11 14:15:36 |

目录
build.gradle配置数据库初始化添加数据删除数据修改数据查询数据补充结束

不知不觉发现都快一个月没有写点东西了,自己最近也是忙于工作与生活当中,这个月经历了很多事情,有开心的也有悲伤的。还好一切都过来了,空下来时想着写点什么好呢,就想着把工作中自己比较喜欢使用的一款有关数据库的开源框架greenDAO,分享下自己的使用过程。

greenDAO是一个针对Android的轻而快速的ORM,它将对象映射到SQLite数据库。由于对Android进行了高度优化,greenDAO提供了出色的性能,并且消耗了最少的内存。


(资料图片仅供参考)

build.gradle配置

buildscript {
repositories {
jcenter()
mavenCentral()
}

dependencies {
classpath "com.android.tools.build:gradle:2.3.1"
classpath "org.greenrobot:greendao-gradle-plugin:3.2.2"
}
}

apply plugin: "com.android.application"
apply plugin: "org.greenrobot.greendao"

android {
buildToolsVersion "25.0.2"
compileSdkVersion 25

defaultConfig {
applicationId "org.greenrobot.greendao.example"
minSdkVersion 15
targetSdkVersion 25
versionCode 1
versionName "3"

testInstrumentationRunner "android.test.InstrumentationTestRunner"
}
}

greendao {
schemaVersion 1000
}

dependencies {
compile "org.greenrobot:greendao:3.2.2"

// 这里当我们使用加密的数据库时就必须添加这条依赖
compile "net.zetetic:android-database-sqlcipher:3.5.6"

compile "com.android.support:appcompat-v7:25.3.1"
compile "com.android.support:recyclerview-v7:25.3.1"
}

uploadArchives.enabled = false

数据库初始化

配置成功后,我们需要创建一个实体类用来生成对应的表,@Entity表示这个实体类一会会在数据库中生成对应的表,@Id表示该字段是id(设置Long类型表示id会自动增长):

@Entity
public class Province {
    @Id
    private Long id;
    private String provinceName;
    private String provinceCode;
    }

写完这些之后将项目进行编译:Build—Make Project,编译成功之后系统会帮助我们生成相应的构造方法和get/set方法,并且还会在我们的包下生成DaoMaster和DaoSession。下面我们就可以对数据库进行初始化了:

public class App extends Application {
    //这里我们定义一个标志,从而去切换数据库的标准模式和加密模式
    public static final boolean ENCRYPTED = true;
    private DaoSession daoSession;
    @Override
    public void onCreate() {
        super.onCreate();
        DevOpenHelper helper = new DevOpenHelper(this, ENCRYPTED ? "province-db-encrypted" : "province-db");
        Database db = ENCRYPTED ? helper.getEncryptedWritableDb("super-secret") : helper.getWritableDb();
        daoSession = new DaoMaster(db).newSession();
    }
    public DaoSession getDaoSession() {
        return daoSession;
    }
}

如果我们想要操作实体类是需要要通过DAO来操作,比如我们想要操作Province实体类,那我们必须先得到一个ProvinceDao,通过ProvinceDao我们可以对数据库进行增删改查等操作:

private ProvinceDao provinceDao;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_mine_fix_school);
        DaoSession daoSession = ((App) getApplication()).getDaoSession();
        provinceDao = daoSession.getProvinceDao();
    }

添加数据

List provinceList = provinceDao.queryBuilder().build().list();
        if (provinceList.size() > 0) {
            //数据库有数据时进行处理
        }else {
            //数据库无数据时,获取网络数据进行数据存储
            api.areas(areaCode)
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new MySubscriber>() {
                    @Override
                    public void onNext(List provinceList) {
                      for (Province province : provinceList) {
                           //插入数据
                           provinceDao.insert(province);
                      }
                });
        }

删除数据

其实删除数据和修改数据是一样的思路,我们要先查找到数据,然后再对数据进行操作:

for (Province province : provinceList) {
            //删除数据
            provinceDao.delete(province);
        }

修改数据

这里我只添加了一个查询条件,就是是id于等于10,最后的unique表示只查询一条数据出来即可:

Province province = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.eq(10)).build().unique();
        if (province == null) {
            //用户不存在
        }else {
            province.setProvinceName("修改浙江省");
            //修改数据
            provinceDao.update(province);
        }

查询数据

其实上面删除和修改都已经涉及到查询了,查询里边有许多非常好用的函数,这里我只用到了一个between表示查询id介于10到20之间的数据

List provinces = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.between(10, 20)).build().list();
        for (Province province : provinces) {
            //输出查询内容
            Log.d("TAG","search:" + province.getProvinceName());
        }

补充

eq:等于notEq:不等于gt:大于lt:小于ge:大于等于le:小于等于between:在某个数值之间的范围

结束

好了,到这里greenDAO的一些简单的功能就可以实现了,在工作的过程中用到了许多数据库,无论是自己用原生的去写,还是去使用一些开源框架。到现在感觉greenDAO应该算是很好用的一款开源框架,自己也很是喜欢。更想进一步的去探究它的奥秘。

到此这篇关于Android数据库greenDAO配置与使用介绍的文章就介绍到这了,更多相关Android greenDAO内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

关键词:

 

热文推荐

Android数据库greenDAO配置与使用介绍

这篇文章主要介绍了Android集成GreenDao数据库,使用数据库存储时候,一

2023-07-11

算力领衔 AI人工智能ETF涨超2%

涨价传闻带领存储器概念走强,人工智能板块再度活跃,AI人工智能ETF(51

2023-07-11

茂业商业:王宗磊辞任公司财务总监

茂业商业:王宗磊辞任公司财务总监-7月10日,茂业商业公告称,董事会于

2023-07-11

2023版养老机构等级评定标准实施指南发布 这几点受关注

2023版养老机构等级评定标准实施指南发布这几点受关注

2023-07-11

王者荣耀芈月宝格丽皮肤多少钱 芈月宝格丽皮肤璀璨新程价格介绍[多图]

王者荣耀芈月宝格丽皮肤璀璨新程已经正式公布,这款皮肤是收款宝格丽联

2023-07-11

货拉拉投资工业搬运机器人制造商“塔斯克”

科技边角料获悉广东塔斯克机器人有限公司日前发生工商变更,新增深圳

2023-07-11

邵伯昭关仇氏源于九姓 以诗书传家 家族非常重视规矩

仇氏族谱仇(音qiú),宋版《百家姓》中排名第242位。据2013年国家相关

2023-07-11

中国足协:两俱乐部官员违规违纪被罚禁入赛场+罚款

据中国足球协会网站消息,两俱乐部官员因违规违纪被处罚。中国足球协会

2023-07-11

蔡珪被称为(蔡珪)

想必现在有很多小伙伴对于蔡珪方面的知识都比较想要了解,那么今天小好

2023-07-11

“棉袄”计划添彩暑假

7月6日,家住安徽省六安市金安区东市街道长安社区、就读于安徽宿州学院

2023-07-11

年逾花甲挑战“足尖儿上的艺术” “芭蕾老人”舞芳华

年逾花甲挑战“足尖儿上的艺术”“芭蕾老人”舞芳华---一群平均年龄62

2023-07-11

发改委8天两次民企座谈会释放了什么信号?

首页头条,发改委8天两次民企座谈会释放了什么信号?,

2023-07-11

沪深股通|宝馨科技7月10日获外资卖出0.23%股份

同花顺数据显示,2023年7月10日,宝馨科技获外资卖出128 54万股,占流

2023-07-11

数字经济推动北京产业重构

阅读提示2023全球数字经济大会上,一系列数字化、智能化全新应用让人耳

2023-07-11

新版剑魔所有台词大全(新版剑姬技能)

来为大家解答以上问题,新版剑魔所有台词大全,新版剑姬技能很多人还不

2023-07-11

西班牙奔牛节庆祝活动已造成十余人受伤

央视新闻客户端据西班牙媒体当地时间7月10日报道,近日在西班牙潘普洛

2023-07-11

可信网络白皮书:传统安全防护思路已不能满足网络演进的诉求

中新网7月10日电 题:可信网络白皮书:传统安全防护思路已不能满足

2023-07-10

巴西戈亚斯州一音乐节发生倒塌事故 至少20人受伤

当地时间7月9日23时16分左右,在巴西戈亚斯州首府戈亚尼亚举行的一场音

2023-07-10

沧州本地人的必吃榜

0317火锅鸡:0317火锅鸡是一家值得一试的餐馆,他们的鸳鸯锅和香味浓郁

2023-07-10

正式官宣!王牌内线加盟辽宁男篮,离开上海,杨鸣出其不意

正式官宣!王牌内线加盟辽宁男篮,离开上海,杨鸣出其不意,杨鸣,李晓旭

2023-07-10