// in the individual module build.gradle files

}

}

之后点击Sync Project

2.2. 在app的build.gradle中配置

apply plugin: ‘com.android.application’

apply plugin: ‘org.greenrobot.greendao’

之后在dependencies中添加依赖

dependencies {

implementation fileTree(dir: ‘libs’, include: [’*.jar’])

implementation ‘androidx.appcompat:appcompat:1.1.0’

implementation ‘androidx.constraintlayout:constraintlayout:1.1.3’

testImplementation ‘junit:junit:4.12’

androidTestImplementation ‘androidx.test.ext:junit:1.1.1’

androidTestImplementation ‘androidx.test.espresso:espresso-core:3.2.0’

implementation ‘org.greenrobot:greendao:3.2.2’ // 添加依赖

}

之后配置数据库相关信息

greendao {

schemaVersion 1 //当前数据库版本

targetGendir ‘src/main/java’//指定生成代码的目录

daoPackage ‘com.lab.search’//生成代码到具体的包下

}

配置就完成了,之后点击Sync Now

在Sync时,出现了下载依赖很慢的事情,所以我在工程目录下的build.gradle将buildscript的repositories改成了

repositories {

google()

//jcenter()

maven{ url ‘http://maven.aliyun.com/nexus/content/groups/public/’}

}

以及

allprojects {

repositories {

google()

//jcenter()

maven{ url ‘http://maven.aliyun.com/nexus/content/groups/public/’}

}

}

把地址改成了阿里云的仓库,下载就快了。

二、使用greendao(1)

2.1. 创建一个实体类

在目录下创建一个Package名为bean,在bean包下面创建一个Java类,类为实体类,即仅有属性以及getter、setter、构造方法以及toString()方法的类,一个实体类则对应一张数据库的表,我将这个实体类取名为UserInfo,类中有id,userName,phoneNumber,address等属性

import org.greenrobot.greendao.annotation.Entity;

import org.greenrobot.greendao.annotation.Id;

import org.greenrobot.greendao.annotation.Property;

@Entity

public class UserInfo {

@Id

private Long id;

@Property(nameInDb = “user_name”)

private String userName;

@Property(nameInDb = “phone_number”)

private String phoneNumber;

@Property(nameInDb = “address”)

private String address;

}

在这里,我用了许多注解,而这些注解有什么作用呢?简单介绍一下在GreenDao中常用的一些注解

@Entity:将我们的java普通类变为一个能够被greenDAO识别的数据库类型的实体类,也就是将这个类标记为要映射到数据库的实体类

@Id:主键,选择使用long或Long,若写成@Id(autoincrement = true)则可标记为自增长。

@Property(nameInDb = “”) :表示该类的这个属性是表的一个字段(即一列),且非主键,nameInDb值则是这个字段的名字,

@NotNull: 不为null

@Transient 不保存于数据库,添加此标记后不会生成数

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

据库表的列

@Index 作为一个属性来创建一个索引,通过name设置索引别名,也可以通过unique给索引添加约束

@Unique: 唯一约束,也就是值必须唯一

@ToOne 表为一对一关系

@ToMany 一对多关系

@Generated 由greendao产生的构造函数或方法,此注释标记的所有代码元素都可以在生成的下一次运行中更改/删除

编译(Make Project)之后,代码就自动生成了构造函数及set get方法,之后再加上toString方法,在进行数据库操作时,可用toString()方法打印来验证结果的正确性。

@Entity

public class UserInfo {

@Id

private long id;

@Property(nameInDb = “user_name”)

private String userName;

@Property(nameInDb = “phone_number”)

private String phoneNumber;

@Property(nameInDb = “address”)

private String address;

@Generated(hash = 459973421)

public UserInfo(long id, String userName, String phoneNumber, String address) {

this.id = id;

this.userName = userName;

this.phoneNumber = phoneNumber;

this.address = address;

}

@Generated(hash = 1279772520)

public UserInfo() {

}

public long getId() {

return this.id;

}

public void setId(long id) {

this.id = id;

}

public String getUserName() {

return this.userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

public String getPhoneNumber() {

return this.phoneNumber;

}

public void setPhoneNumber(String phoneNumber) {

this.phoneNumber = phoneNumber;

}

public String getAddress() {

return this.address;

}

public void setAddress(String address) {

this.address = address;

}

@Override

public String toString() {

return “UserInfo{” +

“id=” + id +

“, userName=’” + userName + ‘’’ +

“, phoneNumber=’” + phoneNumber + ‘’’ +

“, address=’” + address + ‘’’ +

‘}’;

}

}

2.2. 查看UserInfoDAO,DaoMaster及DaoSession

上述操作结束之后,在工程目录下,GreenDAO的生成目录中可以找到相应的数据库操作类,我实体类UserInfo的操作类名称为UserInfoDAO,同时也会自动生成DaoMaster和DaoSession

可以看到生成了三个文件,一个是实体类的操作类,还有DaoMaster,DaoSession等类。

我们先看看DaoMaster类,DaoMaster类主要定义了几个函数

(1)createAllTables、dropAllTables

/** Creates underlying database table using DAOs. */

public static void createAllTables(Database db, boolean ifNotExists) {

UserInfoDao.createTable(db, ifNotExists);

}

/** Drops underlying database table using DAOs. */

public static void dropAllTables(Database db, boolean ifExists) {

UserInfoDao.dropTable(db, ifExists);

}

这两个方法表明了DaoMaster的两个作用,创建和删除所有表。

(2)newSession

public DaoSession newSession() {

return new DaoSession(db, IdentityScopeType.Session, daoConfigMap);

}

public DaoSession newSession(IdentityScopeType type) {

return new DaoSession(db, type, daoConfigMap);

}

这两个类可以创建Session绘画,有两种重载形式,一种可以让我们自定义类型。

(3)构造函数

public DaoMaster(SQLiteDatabase db) {

this(new StandardDatabase(db));

}

public DaoMaster(Database db) {

super(db, SCHEMA_VERSION);

registerDaoClass(UserInfoDao.class);

}

两个重载形式,一个时生成一个数据库,另一个则是注册Config,查看一下registerDaoClass类则会发现,daoConfigMap是一个Map结构

protected final Map<Class<? extends AbstractDao<?, ?>>, DaoConfig> daoConfigMap;

protected void registerDaoClass(Class<? extends AbstractDao<?, ?>> daoClass) {

DaoConfig daoConfig = new DaoConfig(db, daoClass);

daoConfigMap.put(daoClass, daoConfig);

}

通过传进来的UserInfoDao.class作为key,对这个daoConfig进行绑定操作。

而进入到DaoConfig类中,查看DaoConfig的源码时,可以看到注释中的介绍

/**

  • Internal class used by greenDAO. DaoConfig stores essential data for DAOs, and is hold by AbstractDaoMaster. This

  • class will retrieve the required information from the DAO classes.

*/

DaoConfig存储DAO的基本数据,并由AbstractDaoMaster所持有。 该类将从DAO类中检索所需的信息。即将DAO类作为key来检索信息

而DaoSession类则主要是用来操作DAO对象的,它有三个方法

(1)构造函数

public DaoSession(Database db, IdentityScopeType type, Map<Class<? extends AbstractDao<?, ?>>, DaoConfig>

daoConfigMap) {

super(db);

userInfoDaoConfig = daoConfigMap.get(UserInfoDao.class).clone();

userInfoDaoConfig.initIdentityScope(type);

userInfoDao = new UserInfoDao(userInfoDaoConfig, this);

registerDao(UserInfo.class, userInfoDao);

}

从代码中我们可以看到,构造函数做了这么几件事儿

1.取出map中对应DAO的daoConfig

2.初始化缓存类型

3.根据配置可以得到一个DAO对象

4.将DAO对象进行注册,也是通过Map进行管理

(2)getUserInfoDao方法

public UserInfoDao getUserInfoDao() {

return userInfoDao;

}

可返回dao对象,说明可以返回dao对象并对其进行具体的操作了。

(3)clear函数

public void clear() {

userInfoDaoConfig.clearIdentityScope();

}

clear函数就是清楚缓存的函数, clearIdentityScope()

2.3编写DaoManage类

其实,上面操作过后,可以直接进行数据库的使用了,但是这里仍然编写了一个DaoManage类,希望在使用过程中更方便的进行初始化工作

主要内容就是进行各种变量的初始化之后,获得数据库,获取DaoSession对象好对表进行数据操作。

代码如下:

public class DaoManage {

private Context mContext;

//数据库的名称

private static final String DB_NAME = “user.db”;

//多线程中要被共享的要用volatile修饰,Greendao管理类

private volatile static DaoManage mInstance;

//DAOMaster 保存数据库对象

private static DaoMaster mDaoMaster;

//Helper类

private static DaoMaster.DevOpenHelper mHelper;

//Dao对象中的增删改查的对象

private static DaoSession mDaoSession;

private DaoManage(){

}

//使用单例模式来获取GreenDao管理类的对象,即操作数据库的对象

public static DaoManage getInstance(){

if (mInstance == null){

synchronized (DaoManage.class){

if(mInstance == null){

mInstance = new DaoManage();

}

}

}

return mInstance;

}

//初始化上下文

public void init(Context context){

this.mContext = context;

}

//创建(若没有)并获取数据库

public DaoMaster getDaoMaster(){

if(mDaoMaster == null){

//创建一个数据库

mHelper = new DaoMaster.DevOpenHelper(mContext, DB_NAME, null);

mDaoMaster = new DaoMaster(mHelper.getWritableDatabase());

}

return mDaoMaster;

}

//获取DaoSession对象,完成增删改查操作

public DaoSession getDaoSession(){

if(null == mDaoSession){

//若表为空,new一个

if(null == mDaoMaster){

//若数据库为空,则创建数据库

mDaoMaster = getDaoMaster();

}

mDaoSession = mDaoMaster.newSession();

}

return mDaoSession;

}

//关闭连接

public void closeConnection(){

if(mHelper != null){

mHelper.close();

mHelper = null;

}

if(mDaoSession != null){

mDaoSession.clear();

mDaoSession = null;

}

}

}

三、GreenDao使用(2)

3.1. 编写DBHelper类

实际上,GreenDao的数据库操作已经十分简便,我们是可以直接进行使用的,但是为了更加整洁的使用,我还是将增删改查的操作进行了封装,写在了DBHelper类中

(0)加入UserInfoDao对象属性并初始化

private UserInfoDao userInfoDao = DaoManage.getInstance().getDaoSession().getUserInfoDao();

(1)按id查找数据

//查找(按id查找)

public UserInfo queryById(Long id){

List list = userInfoDao.queryBuilder().where(UserInfoDao.Properties.Id.eq(id)).build().list();

UserInfo userInfo = list.isEmpty() ? null : list.get(0);

return userInfo;

}

(2)查找全部

//查找全部

public List queryAll(){

return userInfoDao.queryBuilder().build().list();

}

查询还可以批量查询,多条件查询,模糊搜索等等内容,由于太多,就不全部列出来了,可以查阅相关文档按照需要进行使用。

(3)增

//增加

public void add(UserInfo userInfo){

if (queryById(userInfo.getId()) == null){

userInfoDao.insert(userInfo);

}else{

userInfoDao.update(userInfo);

}

}

//批量增加

public void add(List userInfoList){

userInfoDao.insertInTx(userInfoList);

}

(4)删

//删除一个对象

public void delete(UserInfo userInfo){

userInfoDao.delete(userInfo);

}

//删除一个列表的对象

public void deleteByList(List userInfoList){

userInfoDao.deleteInTx(userInfoList);

}

//按主键删除

public void delteByKey(long key){

userInfoDao.deleteByKey(key);

}

//按主键列表删除

public void deleteByKeyList(List idList){

userInfoDao.deleteByKeyInTx(idList);

}

//删除所有

public void deleteAll(){

userInfoDao.deleteAll();

}

(5)改

//修改

public boolean update(UserInfo userInfo){

Android数据库框架-GreenDao入门,阿里P8架构师Android大厂面试题总结相关推荐

  1. 阿里P8架构师谈:分布式架构设计12精讲

    分布式架构设计包含: 分布式缓存 分布式消息中间件 分库分表.读写分离 单点登录等 想成为阿里160万年薪的P8架构师?你必须掌握如下6大技能体系! 阿里P8架构师谈:分布式架构系统拆分原则.需求.微 ...

  2. 阿里P8架构师谈:Quartz调度框架详解、运用场景、与集群部署实践

    以下将分别从Quartz架构简介.集群部署实践.Quartz监控.集群原理分析详解Quartz任务调度框架. Quartz简介 Quartz是Java领域最著名的开源任务调度工具,是一个任务调度框架, ...

  3. 阿里P8架构师进阶心得:分布式数据库架构MyCat学习笔记送给你

    前言: MyCat 是一个数据库分库分表中间件,使用 MyCat 可以非常方便地实现数据库的分库分表查询,并且减少项目中的业务代码.今天我们将通过数据库架构发展的演变来介绍 MyCat 的诞生背景,以 ...

  4. 阿里P8架构师谈:主流RPC框架详解,以及与SOA、SOAP、REST的区别

    什么是RPC RPC(Remote Procedure Call Protocol)--远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议. 简言之,RPC使 ...

  5. 阿里P8架构师谈:Web前端、应用服务器、数据库SQL等性能优化总结

    web前端性能优化 Web前端指网站业务逻辑之前的部分,包括: 1.浏览器加载 2.网站视图模型 3.图片服务 4.CDN服务等 主要优化手段有优化浏览器访问,使用反向代理,CDN等. 1.浏览器访问 ...

  6. 阿里P8架构师谈:数据库、JVM、缓存、SQL等性能调优方法和原则

    编辑 性能优化基本是BAT等一线互联网公司程序员必备的技能,以下为大家完整揭晓性能完整的优化方案和方法:包含web网站调优.数据库.JVM调优.架构调优等方案. 第一:Web网站调优 1.尽可能减少H ...

  7. 阿里P8架构师谈:MySQL数据库的索引原理、与慢SQL优化的5大原则

    MySQL凭借着出色的性能.低廉的成本.丰富的资源,已经成为绝大多数互联网公司的首选关系型数据库.虽然性能出色,但所谓"好马配好鞍",如何能够更好的使用它,已经成为开发工程师的必修 ...

  8. 阿里P8架构师谈:从单体架构、到SOA、再到微服务的架构设计详解

    本文涉及的内容以及知识点如下: 1.单体架构 2.单体架构的拆分 3.SOA与微服务的区别 4.微服务的优缺点 5.微服务的消息 6.服务集成 7.数据的去中心化 单体架构 Web应用程序发展的早期, ...

  9. 阿里P8架构师谈:架构设计经验汇总

    架构设计更多的是实践经验总结,以下架构设计经验,我会陆续补充完整. 一:数据库拆分原则 阿里P8架构师谈:架构设计之数据库拆分六大原则 二:缓存选择原则 阿里P8架构师谈:分布式缓存的应用场景.选型比 ...

最新文章

  1. git add 文件夹_Git的下载安装以及基本操作
  2. 漫画:什么是 “代理模式” ?
  3. unrecognized font family iconfont2
  4. 最短路径:Dijkstra算法和Floyd算法
  5. Codeforces Round #726 (Div. 2) F. Figure Fixing 二分图 + 思维
  6. 图Graph--最小生成树
  7. 田渊栋:业余做研究的经验
  8. 美国计算机科学联赛获奖,【竞赛获奖】西安高新一中国际班学子在2018-2019美国计算机科学联赛 (ACSL)积分赛中创造历史!...
  9. Axure经典实例高保真交互下载(微信元件高保真交互库+微信原型交互+安卓设备模板含登录注册引导欢迎流程+ios苹果设备模板)
  10. WebApp前端页面性能优化建议
  11. Nginx默认虚拟主机、 Nginx用户认证、Nginx域名重定向、访问日志·····
  12. 【Linux开发】OpenCV在ARM-linux上的移植过程遇到的问题2---CMAKE配置问题
  13. 评人工智能如何走向新阶段?
  14. java基础学习总结_java基础班学习心得(感言)
  15. ffmpeg推流及python管道控制ffmpeg推流
  16. 如何找到自己正确需要的抖音搜索关键词
  17. 【微信小程序】使用 Cryptojs 解密微信绑定手机号码
  18. 奇特的锡纸海鲜小吃:吃到嗨都不会发胖的辣卤海鲜!值得开一家哦!
  19. 微信网页端软键盘收起点击事件失效
  20. 嵌入式产品测试工装——ETest

热门文章

  1. [运维]Dell R710 raid配置
  2. 焦虑症是什么?患上焦虑症该注意什么呢?
  3. 多项式拟合中构造正交多项式函数族
  4. oracle中的iw和ww学习
  5. Scrapy框架--CrawlSpider (详解+例子)
  6. 还原 Windows 11 右键菜单样式
  7. Git 笔记 - git pull
  8. 结构化网格与非结构化网格 学习记录
  9. 智能电子中的自动化控制中的工业自动化
  10. 智慧交管三维可视化决策系统平台(数字孪生)-解决方案开发案例