目录
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 25defaultConfig {
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(); }
添加数据
ListprovinceList = 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之间的数据
Listprovinces = 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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
关键词:
X 关闭
X 关闭
- 15G资费不大降!三大运营商谁提供的5G网速最快?中国信通院给出答案
- 2联想拯救者Y70发布最新预告:售价2970元起 迄今最便宜的骁龙8+旗舰
- 3亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 4现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 5如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 6AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 7转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 8充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 9好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 10名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?