Android 数据库框架GreenDao使用
1.GreenDao3介绍
(1)基本概念

(2)GreenDao3工作原理

(3)GreenDao优点

(4)GreenDao3版本的改进

2.GreenDao3的相关配置概念介绍
(1)配置项目(Project)的build.gradle

(2)配置模组(Module)的build.gradle



3.GreenDao3配置实战
(1)打开现有的Android studio工程
(2)配置项目(Project)的build.gradle

buildscript{
    //repositories相当于一个存储jar包的仓库
    repositories {
        mavenCentral()  //到网上的Maven仓库的服务器里下载库文件
    }
    //dependencies包含所有真正依赖的库文件
    dependencies{
        //将GreenDao的插件库文件引入项目
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'
    }
}
(3)配置模组(Module)的build.gradle
在文件的最后添加

//应用GreenDao插件
apply plugin: 'org.greenrobot.greendao'
greendao{ //设置greendao的相关参数
schemaVersion 3 //设置数据库版本
daoPackage 'com.example.lucky.mygreendaotest.gen' //生成DAO、DAOMaster、DAOSession的包名(这句代码应根据实际project文件位置进行相应修改)
targetGenDir 'src/main/java' //生成DAOs、DAOMaster、DAOSession的目录
}
dependencies{
implementation fileTree(dir: 'libs', include: ['*.jar']) //用于项目编译的库文件及所在目录
implementation 'com.android.support:appcompat-v7:28.0.0'
//导入greendao的相关库文件
implementation 'org.greenrobot:greendao:3.2.0'
implementation 'org.greenrobot:greendao-generator:3.2.0' }
注意:以上代码中有一处要根据实际情况进行修改
daoPackage 'com.example.lucky.mygreendaotest.gen' //生成DAO、DAOMaster、DAOSession的包名(这句代码应根据实际project文件位置进行相应修改)
其中com.example.lucky.mygreendaotest为工程的包名,可用实际工程的manifest.xml文件的包名(package对应内容)替换
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.administrator.test62360safeguard">
(4) 进行项目同步
点击Sync Now

可见如下图

(5)实体类及其注解
<1>介绍

<2>实体类注解及其作用




<3>创建实体类并完成注解

<4>新建实体类后,通过build--->make project 编译工程,会自动生成代码(实体类BlackListCallEntity中有一部分、还有DaoMaster.java、DaoSession.java、BlackListCallEntityDao.java)

注意:主键id的数据类型是Long而不是long
以下是未编译的实体类BlackListCallEntity的代码:
package com.example.administrator.test62360safeguard.Entity; import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;
import org.greenrobot.greendao.annotation.Generated; @Entity(
//设置数据库的表名
nameInDb ="black_list_call"
)
public class BlackListCallEntity {
@Id(autoincrement = true)
private Long id; //注意:id的数据类型是Long而不是long
private String phoneNumber;
private String functionType;
}
经过编译后的实体类:
package com.example.administrator.test62360safeguard.Entity; import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;
import org.greenrobot.greendao.annotation.Generated; @Entity(
//设置数据库的表名
nameInDb ="black_list_call"
)
public class BlackListCallEntity {
@Id(autoincrement = true)
private Long id; //注意:id的类型是Long而不是long
private String phoneNumber;
private String functionType;
@Generated(hash = 533022796)
public BlackListCallEntity(Long id, String phoneNumber, String functionType) {
this.id = id;
this.phoneNumber = phoneNumber;
this.functionType = functionType;
}
@Generated(hash = 1836403501)
public BlackListCallEntity() {
}
public Long getId() {
return this.id;
}
public void setId(Long id) {
this.id = id;
}
public String getPhoneNumber() {
return this.phoneNumber;
}
public void setPhoneNumber(String phoneNumber) {
this.phoneNumber = phoneNumber;
}
public String getFunctionType() {
return this.functionType;
}
public void setFunctionType(String functionType) {
this.functionType = functionType;
} }
(6)新建2个java类(HMROpenHelper、MyGreenDaoApplication)
<1>HMROpenHelper类的源码
package com.example.lucky.mygreendaotest; import android.content.Context;
import android.database.sqlite.SQLiteDatabase; import com.example.lucky.mygreendaotest.gen.DaoMaster; //数据库创建工具类
public class HMROpenHelper extends DaoMaster.OpenHelper {
//构造函数,参数2 name为数据库名称
public HMROpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) {
super(context, name, factory);
}
}
<2>MyApplication类的源码
通常我们是不需要指定一个Application的,系统会自动帮我们创建,如果需要创建自己的Application,那也很简单!创建一个类继承Application并在AndroidManifest.xml文件中的application标签中进行注册(只需要给application标签增加name属性,并添加自己的 Application的名字即可)
当Android程序启动时系统会创建一个Application对象,用来存储系统的一些信息。
Android系统自动会为每个程序运行时创建一个Application类的对象且只创建一个,所以Application可以说是单例(singleton)模式的一个类。
package com.example.administrator.test62360safeguard; import android.app.Application;
import android.database.sqlite.SQLiteDatabase; import com.example.administrator.test62360safeguard.GreenDao.DaoMaster;
import com.example.administrator.test62360safeguard.GreenDao.DaoSession;
import com.example.administrator.test62360safeguard.GreenDaoUtils.HMROpenHelper; /**
* 注意:MyApplication类继承Application,需要在AndroidManifest.xml文件中进行相关设置
* android:name=".MyApplication"
* MyApplication类的作用是封装数据库对象
*/
public class MyApplication extends Application {
private SQLiteDatabase db; //SQLiteDatabase数据库对象
private DaoMaster daoMaster; //daoMaster对象
private DaoSession daoSession; //daoSession对象
public static MyApplication instances; //声明本类的实例对象 @Override
public void onCreate() {
super.onCreate();
instances=this; //给实例对象赋值
setDatabase();
} private void setDatabase() {
//创建数据库,参数2是所创建的数据库的名称
HMROpenHelper hmrOpenHelper=new HMROpenHelper(this,"mydb1",null);
db=hmrOpenHelper.getWritableDatabase(); //获取数据库对象
daoMaster=new DaoMaster(db); //获取DaoMaster对象
daoSession=daoMaster.newSession(); } //获取instances 对象
public static MyApplication getInstances(){
return instances;
} //获取daoSession对象
public DaoSession getDaoSession(){
return daoSession;
} public SQLiteDatabase getDb(){
return db;
}
}
(7)编译工程,安装到模拟器后,打开应用时,就会自动创建数据库
模拟器中app内的数据库文件导出方法:

6.GreenDao3添加记录(SQLite 增)
(1)基本原理





7.GreenDao3删除记录(SQLite 删)




8.GreenDao3修改记录(SQLite 改)




参考文献:https://www.jianshu.com/p/793f77feeb89
https://www.cnblogs.com/tonycheng93/p/6295724.html(推荐)
Android 数据库框架GreenDao使用的更多相关文章
- Android数据库框架——GreenDao轻量级的对象关系映射框架,永久告别sqlite
		
Android数据库框架--GreenDao轻量级的对象关系映射框架,永久告别sqlite 前不久,我在写了ORMLite这个框架的博文 Android数据库框架--ORMLite轻量级的对象关系映射 ...
 - Android 数据库框架GreenDao实战使用
		
1.添加记录(SQLite 增) 2.删除记录(SQLite 删) 3.修改记录(SQLite 改) 4.查询记录(SQLite 查) <1> DAO查询 <2>QueryBu ...
 - Android 数据库框架总结(转)
		
转自 http://blog.csdn.net/da_caoyuan/article/details/61414626 一:OrmLite 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完 ...
 - Android 数据库框架总结,总有一个适合你!
		
一:OrmLite 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完善:4.文档全面.缺点:1.基于反射,效率较低(本人还没有觉得效率低):2.缺少中文翻译文档 jar包 地址:http: ...
 - Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包
		
Android数据库框架--ORMLite轻量级的对象关系映射(ORM)Java包 事实上,我想写数据库的念头已经很久了,在之前写了一个答题系统的小项目那只是初步的带了一下数据库,数据库是比较强大的, ...
 - ORM数据库框架 greenDAO SQLite MD
		
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
 - Android 数据库框架OrmLite的使用(一)
		
在这里记录下最基本的用法,官网上可了解相关的介绍. 1.下载OrmLite jar 在下载android的:ormlite-android-4.48.jar和ormlite-core-4.48.jar ...
 - Android 数据库框架ormlite
		
Android 数据库框架ormlite 使用精要 前言 本篇博客记录一下笔者在实际开发中使用到的一个数据库框架,这个可以让我们快速实现数据库操作,避免频繁手写sql,提高我们的开发效率,减少出错的机 ...
 - Android数据库框架-----ORMLite关联表的使用
		
上一篇已经对ORMLite框架做了简单的介绍:Android数据库框架-----ORMLite 的基本用法~~本篇将介绍项目可能会使用到的一些用法,也为我们的使用ORMLite框架总结出一个较合理的用 ...
 
随机推荐
- 【bzoj2186】[Sdoi2008]沙拉公主的困惑
			
2186: [Sdoi2008]沙拉公主的困惑 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 3303 Solved: 1129[Submit][S ...
 - Hyperledger Fabric Ordering Service过程
			
排序服务在超级账本 Fabric 网络中起到十分核心的作用.所有交易在发送给 Committer 进行验证接受之前,需要先经过排序服务进行全局排序. 在目前架构中,排序服务的功能被抽取出来,作为单独的 ...
 - 5.WHERE 子句
			
WHERE 子句用于规定选择的标准. WHERE 子句 如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句. 语法 SELECT 列名称 FROM 表名称 WHERE 列 运 ...
 - Linux、Windows中的相对路径和绝对路径
			
获取系统的分隔符的方式:System.getProperty("file.separator") Windows为 \ Linux为/ Windows绝对路径: 以盘符开始 ...
 - CentOS下配置防火墙 配置nat转发服务
			
CentOS下配置iptables防火墙 linux NAT(iptables)配置 CentOS下配置iptables 1,vim /etc/sysconfig/network 这里可以更改主机 ...
 - 【留用】C#的一些好的书籍
			
浏览博客的时候发现一篇推荐的C#书籍,感觉真的不错,涉略过几本,水平问题,没看的很深入,正在努力,留用了!!! http://www.cnblogs.com/tongming/p/3879752.ht ...
 - web集群时session同步的3种方法
			
在做了web集群后,你肯定会首先考虑session同步问题,因为通过负载均衡后,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,一个登录用户,一会是登录状态,一会又不是 ...
 - SQL SERVER2008 R2修改Server Collation--文檔沒細看先存下來.
			
HOW TO: RESTORE THE MASTER DATABASE IN SQL SERVER 2012 by Thomas LaRock | Jan 14, 2014 | MSSQL, SQL ...
 - 「POJ 2699」The Maximum Number of Strong Kings
			
题目链接 戳我 \(Describe\) 一场联赛可以表示成一个完全图,点表示参赛选手,任意两点u, v之间有且仅有一条有向边\((u, v)\)或\((v, u)\),表示\(u\)打败\(v\)或 ...
 - ajaxfileupload 跨域 (二级域名) 可行办法
			
ajaxfileupload 跨二级域名 如 aa.fei.com 到 bb.fei.com 是可行的. 1.首先在html页面 ajaxfileupload上方加入 document.domain= ...