GreenDao 3.0解析

2024-06-24 05:38
文章标签 greendao 3.0 解析

本文主要是介绍GreenDao 3.0解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. GreenDao 3.0简介:
    在Android开发中,数据缓存的开发可能会使用到SQLite,然而在使用它的时候,我们往往要进行许多额外的工作,编写原生的SQL语句与解析查询结果等。所以适应Android的ORM框架就产生了。
    目前较为流行的Android的ORM框架就是GreenDao, ORM就是关系映射(Object Relation Mapping),即对象关系映射。它的实现思想就是将关系数据库中表的数据映射为对象,以对象的形式展现,这样开发人员就可以把数据库的操作转化为对这些对象的操作。因此它的目的就是为了方便开发人员用面向对象的思想来实现数据库的操作。
    这里写图片描述
    大家应该对ORM框架有了初步的了解,下面我们就来使用GreenDao,我们就通过GreenDao的官网,http://greenrobot.org/greendao/ ,来学习如何对它进行使用。
    这里写图片描述
    从图中我们可以知道GreenDao已经升级到了3.0版本,相比之前的旧版本,3.0版本采用注解的方式通过编译方式生成Java数据对象和DAO对象。相比之前需要通过新建GreenDaoGenerator工程生成Java数据对象(实体)和DAO对象,大大减少了使用的成本。
  2. GreenDao 3.0使用
    我们跟着官网的步骤来对学习如何使用GreenDao 3.0
    1) 导入相关的包
    这里写图片描述
    根据上面的内容,我们需要在在gradle的dependencies中导入如下内容
compile 'org.greenrobot:greendao:3.0.1'
compile 'org.greenrobot:greendao-generator:3.0.0'

2) 配置gradle
这里写图片描述
官网上说,GreenDao 3.0通过一个新的插件来生成代码,这个插件会去浏览所有的被Entity注释的类去收集表信息,并生成3个类,DaoSession,DaoMaster,和所有的Dao类。使用这个插件的话,需要在gradle中配置如下的内容

apply plugin: 'org.greenrobot.greendao'buildscript {repositories {mavenCentral()}dependencies {classpath 'org.greenrobot:greendao-gradle-plugin:3.0.0'}
}

这里写图片描述
同时一般我们还会添加如下的内容

greendao {schemaVersion 1daoPackage 'com.example.jikeyoujikeyou.greendao2'targetGenDir 'src/main/java'
}

需要说明一下含义:
schemaVersion:指定数据库schema版本号,迁移等操作会用到
daoPackage:通过gradle插件生成的数据库相关文件的包名,默认为你的entity所在的包名
targetGenDir:这就是我们上面说到的自定义生成数据库文件的目录了,可以将生成的文件放到我们的java目录中,而不是build中,这样就不用额外的设置资源目录了
3) 新建实体类
以下为基础属性注解
这里写图片描述
@Id :主键 long/Long型,可以通过@Id(autoincrement = true)设置自增长
@Property:设置一个非默认关系映射所对应的列名,默认是的使用字段名 举例:@Property (nameInDb=”name”)
@NotNul:设置数据库表当前列不能为空
@Transient :添加次标记之后不会生成数据库表的列

@Entity
public class User {@Id(autoincrement = true)private Long id;private String name;@Transientprivate int tempUsageCount; // not persisted}

我们在新建实体类的时候,id是我们数据库表的主键,上面代码中我给id使用自增长的注解,如果这里不设置的话,我们就需要在创建User对象的时候给id赋值,如果不这样做,就会报出空指针的异常。
这里写图片描述
上面为索引注解
@Index:使用@Index作为一个属性来创建一个索引,通过name设置索引别名,也可以通过unique给索引添加约束
@Unique:向数据库列添加了一个唯一的约束
这里写图片描述
关系注解
@ToOne:定义与另一个实体(一个实体对象)的关系
@ToMany:定义与多个实体对象的关系
接下来让我们点击as中Build菜单栏中的Make Project,make完成之后会发现我们的User类中突然多了好多代码,这就是GreenDAO自动为你生成的了,代码如下

@Entity
public class User {@Id(autoincrement = true)private Long id;private String name;private int age;public int getAge() {return this.age;}public void setAge(int age) {this.age = age;}public String getName() {return this.name;}public void setName(String name) {this.name = name;}public Long getId() {return this.id;}public void setId(Long id) {this.id = id;}@Generated(hash = 1309193360)public User(Long id, String name, int age) {this.id = id;this.name = name;this.age = age;}@Generated(hash = 586692638)public User() {}}

Make Project后生成了如下的类:
这里写图片描述
4) 使用GreenDAO进行增删改查
这里我都封装在了一个类DBManager之中

public class DBManager {private static final String dbName = "DBdemo";private static DBManager mInstance;private final Context context;private DaoMaster.DevOpenHelper openHelper;private DBManager(Context context) {this.context = context;openHelper = new DaoMaster.DevOpenHelper(context, dbName, null);}//单例模式public static DBManager getInstance(Context context) {if (mInstance == null) {synchronized (DBManager.class) {if (mInstance == null) {mInstance = new DBManager(context);}}}return mInstance;}//可读数据库private SQLiteDatabase getReadableDatabase() {if (openHelper == null) {openHelper = new DaoMaster.DevOpenHelper(context, dbName, null);}SQLiteDatabase db = openHelper.getReadableDatabase();return db;}//可写数据库private SQLiteDatabase getWritableDatabase() {if (openHelper == null) {openHelper = new DaoMaster.DevOpenHelper(context, dbName, null);}SQLiteDatabase db = openHelper.getWritableDatabase();return db;}//插入数据public void insertUser(User user) {DaoMaster daoMaster = new DaoMaster(getWritableDatabase());DaoSession daoSession = daoMaster.newSession();UserDao userDao = daoSession.getUserDao();userDao.insert(user);}//插入数据集合public void insertUserList(List<User> users) {if (users == null || users.isEmpty()) {return;}DaoMaster daoMaster = new DaoMaster(getWritableDatabase());DaoSession daoSession = daoMaster.newSession();UserDao userDao = daoSession.getUserDao();userDao.insertInTx(users);}//删除数据public void deleteUser(User user) {DaoMaster daoMaster = new DaoMaster(getWritableDatabase());DaoSession daoSession = daoMaster.newSession();UserDao userDao = daoSession.getUserDao();userDao.delete(user);}//更新数据public void updateUser(User user) {DaoMaster daoMaster = new DaoMaster(getWritableDatabase());DaoSession daoSession = daoMaster.newSession();UserDao userDao = daoSession.getUserDao();userDao.update(user);}/*** 查询用户列表*/public List<User> queryUserList() {DaoMaster daoMaster = new DaoMaster(getReadableDatabase());DaoSession daoSession = daoMaster.newSession();UserDao userDao = daoSession.getUserDao();QueryBuilder<User> qb = userDao.queryBuilder();List<User> list = qb.list();return list;}}

对上述代码说明一下:
(1) 一个DaoMaster就代表着一个数据库的连接;DaoSession可以让我们使用一些Entity的基本操作和获取Dao操作类,DaoSession可以创建多个,每一个都是属于同一个数据库连接的。
(2) 通过userDao的queryBuilder()方法,生成一个查找构造器,可以给构造器添加where条件判断、按照某某字段排序以及查询的条数等基本的数据库操作。list()方法表示查询的结果为一个集合。
5) 进行试验
接下来,我在MainAcitivty写入如下代码,进行试验

public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);testDBManager();}private void testDBManager() {DBManager dbManager = DBManager.getInstance(this);for (int i = 0; i < 10; i++) {User user = new User();user.setAge(i * 3);user.setName("我是第" + i + "选手");dbManager.insertUser(user);}List<User> userList = dbManager.queryUserList();for (User user : userList) {Log.e("MainActivity", "queryUserList--before-->" + user.getId() + "--" + user.getName() + "--" + user.getAge());if (user.getId() == 5) {user.setAge(17);dbManager.updateUser(user);}if (user.getId() == 7) {dbManager.deleteUser(user);}}userList = dbManager.queryUserList();for (User user : userList) {Log.e("MainActivity", "queryUserList--after--->" + user.getId() + "---" + user.getName() + "--" + user.getAge());}}
}

运行程序,输出如下内容,说明使用GreenDAO成功!
这里写图片描述

这篇关于GreenDao 3.0解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1089312

相关文章

解析 XML 和 INI

XML 1.TinyXML库 TinyXML是一个C++的XML解析库  使用介绍: https://www.cnblogs.com/mythou/archive/2011/11/27/2265169.html    使用的时候,只要把 tinyxml.h、tinystr.h、tinystr.cpp、tinyxml.cpp、tinyxmlerror.cpp、tinyxmlparser.

tf.split()函数解析

API原型(TensorFlow 1.8.0): tf.split(     value,     num_or_size_splits,     axis=0,     num=None,     name='split' ) 这个函数是用来切割张量的。输入切割的张量和参数,返回切割的结果。  value传入的就是需要切割的张量。  这个函数有两种切割的方式: 以三个维度的张量为例,比如说一

陀螺仪LSM6DSV16X与AI集成(8)----MotionFX库解析空间坐标

陀螺仪LSM6DSV16X与AI集成.8--MotionFX库解析空间坐标 概述视频教学样品申请源码下载开启CRC串口设置开启X-CUBE-MEMS1设置加速度和角速度量程速率选择设置FIFO速率设置FIFO时间戳批处理速率配置过滤链初始化定义MotionFX文件卡尔曼滤波算法主程序执行流程lsm6dsv16x_motion_fx_determin欧拉角简介演示 概述 本文将探讨

【文末附gpt升级秘笈】腾讯元宝AI搜索解析能力升级:千万字超长文处理的新里程碑

腾讯元宝AI搜索解析能力升级:千万字超长文处理的新里程碑 一、引言 随着人工智能技术的飞速发展,自然语言处理(NLP)和机器学习(ML)在各行各业的应用日益广泛。其中,AI搜索解析能力作为信息检索和知识抽取的核心技术,受到了广泛的关注和研究。腾讯作为互联网行业的领军企业,其在AI领域的探索和创新一直走在前列。近日,腾讯旗下的AI大模型应用——腾讯元宝,迎来了1.1.7版本的升级,新版本在AI搜

消息认证码解析

1. 什么是消息认证码         消息认证码(Message Authentication Code)是一种确认完整性并进行认证的技术,取三个单词的首字母,简称为MAC。         消息认证码的输入包括任意长度的消息和一个发送者与接收者之间共享的密钥,它可以输出固定长度的数据,这个数据称为MAC值。         根据任意长度的消息输出固定长度的数据,这一点和单向散列函数很类似

问题1,PE文件转到内存中出现解析PE不正确的问题

1,使用fopen(FileName, “r”) r的方式读取文件到内存,此时就可能存在问题了,r以只读方式,有时候不表示字符的有可能就不读了,那么内存中就不会是完整的原始文件。所以此时要采用rb,二进制读取的方式。 bool ReadFileToMem(char* FileName, char**buf) { FILE* f; f = fopen(FileName, “rb”); if

[大师C语言(第三十六篇)]C语言信号处理:深入解析与实战

引言 在计算机科学中,信号是一种软件中断,它允许进程之间或进程与内核之间进行通信。信号处理是操作系统中的一个重要概念,它允许程序对各种事件做出响应,例如用户中断、硬件异常和系统调用。C语言作为一门接近硬件的编程语言,提供了强大的信号处理能力。本文将深入探讨C语言信号处理的技术和方法,帮助读者掌握C语言处理信号的高级技巧。 第一部分:C语言信号处理基础 1.1 信号的概念 在Unix-lik

免费内网穿透工具 ,快解析内网穿透解决方案

在IPv4公网IP严重不足的环境下,内网穿透技术越来越多的被人们所使用,使用内网穿透技术的好处有很多。 1:无需公网ip 物以稀为贵,由于可用的公网IP地址越来越少,价格也是水涨船高,一个固定公网IP一年的成本要上万,而使用内网穿透技术则不需要公网IP的支持。 2:提高安全性 使用内网穿透技术,无需在路由器映射端口,我们知道黑客通常会使用端口扫描来寻找攻击对象,不映射端口能大大提高服务器的安全

混合密码系统解析

1. 概述         混合密码系统(hybrid cryptosystem)是将对称密码和非对称密码的优势相结合的方法。一般情况下,将两种不同的方式相结合的做法就称为混合(hybrid)。用混合动力汽车来类比的话,就相当于是一种将发动机(对称密码)和电动机(非对称密码)相结合的系统。         混合密码系统中会先用快速的对称密码来对消息进行加密,这样消息就被转换为了密文从而也就保证

带你解析Dagger2

1. Dagger2简介: Dagger2是Dagger1的分支,由谷歌公司接手开发,目前的版本是2.0。Dagger2是受到AutoValue项目的启发。 刚开始,Dagger2解决问题的基本思想是:利用生成和写的代码混合达到看似所有的产生和提供依赖的代码都是手写的样子。 Dagger2具有以下好处: 1) 依赖的注入和配置独立于组件之外,注入的对象在一个独立、不耦合的地方初始化,这样在改