Android使用DevRing框架搭建数据库实体类以及使用
一、引用DevRing依赖
//导入DevRing依赖implementation 'com.ljy.ring:devring:1.1.8'创建数据库表的依赖implementation 'org.greenrobot:greendao:3.2.2' // add libraryimplementation 'org.greenrobot:greendao-generator:3.0.0'
二、修改工程目录下的.idea->gradle.xml文件,添加:
<option name="delegatedBuild" value="false" />
三、创建生成实体类的执行类
public class TableDaoGenerator {private static void addTaskDetail(Schema schema) {//实体类1Entity entity = schema.addEntity("User");//添加id属性//entity.addIdProperty();//添加列userId,指定非空,默认可为空entity.addLongProperty("Id").primaryKey();entity.addLongProperty("userId");entity.addStringProperty("realName");entity.addStringProperty("mobile");entity.addStringProperty("createTime");entity.addStringProperty("modifyTime");entity.addStringProperty("sex");entity.addStringProperty("userPhoto");entity.addStringProperty("certificateNumber");entity.addStringProperty("employeeNo");entity.addStringProperty("terminalPassword");entity.addIntProperty("userCabinetType");entity.addStringProperty("cardNum");entity.addStringProperty("spaceNos");entity.addStringProperty("fingerId");entity.addStringProperty("bindingUserTime");entity.addStringProperty("isTestTimeout");entity.addBooleanProperty("isDelete");entity.addIntProperty("userType");entity.addStringProperty("addFromTag");entity.addStringProperty("userTypeStr");//实体类2Entity entity2 = schema.addEntity("User01");//添加id属性//entity.addIdProperty();//添加列userId,指定非空,默认可为空entity2.addLongProperty("Id").primaryKey();entity2.addLongProperty("userId");entity2.addStringProperty("realName");entity2.addStringProperty("mobile");entity2.addStringProperty("createTime");entity2.addStringProperty("modifyTime");entity2.addStringProperty("sex");entity2.addStringProperty("userPhoto");entity2.addStringProperty("certificateNumber");entity2.addStringProperty("employeeNo");//实体类...}public static void main(String[] args) throws Exception {//第一个参数是数据库版本号,第二个参数是所在包名Schema schema = new Schema(1,"been");addTaskDetail(schema);try {//第二个参数是我们前面新建的空文件夹db,这里采用绝对路径的写法new DaoGenerator().generateAll(schema, "E:\\Android\\Projects\\SpDemo\\app\\src\\main\\java\\com\\example\\spdemo\\db");} catch (Exception e) {e.printStackTrace();}}}
执行即可在db包下生成对应的实体类和配置类:
注意:
自动生成的类中都需要手动导包,每个实体类的Dao类中都需要重写hasKey(对应实体类 entity)
四、创建每个数据库表对应的管理者类GreenTableManager(继承数据库管理者基类)
//User01表
public class User01GreenTableManager extends GreenTableManager<User01, Long> {private DaoSession mDaoSession;public User01GreenTableManager(DaoSession daoSession) {this.mDaoSession = daoSession;}@Overridepublic AbstractDao<been.User01, Long> getDao() {return mDaoSession.getUser01Dao();}
}//User表
public class UserGreenTableManager extends GreenTableManager<User, Long> {private DaoSession mDaoSession;public UserGreenTableManager(DaoSession daoSession) {this.mDaoSession = daoSession;}@Overridepublic AbstractDao<User, Long> getDao() {return mDaoSession.getUserDao();}
}
五、创建GreenDBManager类继承IDBManager接口
由于GreenDao的特殊性以及具体数据表的不确定,无法很好地集成到DevRing当中。 所以需要实现IDBManager接口,在实现类中手动增加实体类对应的GreenTableManager类。
/*** author: ljy* date: 2018/3/10* description:* 由于GreenDao的特殊性以及具体数据表的不确定,无法很好地集成到DevRing当中。* 所以需要实现IDBManager接口,并通过DevRing.configureDB()方法传入。* 1.在init()中对数据库进行初始化操作,如建库建表。* 2.在putTableManager()方法中将数据表管理者存进参数map中,请记清楚key值* 后面对数据表的操作是通过DevRing.tableManager(key)方法得到数据表管理者,然后进行相关增删改查。* 3.可在本类中添加IDBManager接口以外的方法* ,然后通过DevRing.<GreenDBManager>dbManager()来调用。**/public class GreenDBManager implements IDBManager {DaoSession mDaoSession;UserGreenTableManager userGreenTableManager;User01GreenTableManager user01GreenTableManager;@Overridepublic void init() {String dbName = "intelligent_cabinet.db";Integer dbVersion = DaoMaster.SCHEMA_VERSION;Class<? extends AbstractDao<?, ?>>[] classes = new Class[]{UserDao.class,User01Dao.class,};//这里使用DevRing提供的GreenOpenHelper对DaoMaster进行初始化,这样就可以实现数据库升级时的数据迁移//默认的DaoMaster.OpenHelper不具备数据迁移功能,它会在数据库升级时将数据删除。GreenOpenHelper openHelper = new GreenOpenHelper(DevRing.application(), dbName, dbVersion, classes);DaoMaster daoMaster = new DaoMaster(openHelper.getWritableDatabase());daoMaster.createAllTables(daoMaster.getDatabase(),true);
// DaoMaster daoMaster = new DaoMaster(greenOpenHelper.getEncryptedWritableDb("your_secret"));//加密mDaoSession = daoMaster.newSession();Log.i("初始化数据开始","初始化数据开始1====================================");userGreenTableManager = new UserGreenTableManager(mDaoSession);user01GreenTableManager = new User01GreenTableManager(mDaoSession);Log.i("初始化数据开始","初始化数据开始2====================================");//查看数据库更新版本时数据迁移的logMigrationHelper.DEBUG = false;//数据库增删改查时的logQueryBuilder.LOG_SQL = false;QueryBuilder.LOG_VALUES = false;//清空缓存mDaoSession.clear();}@Overridepublic void putTableManager(SimpleArrayMap<Object, ITableManger> mapTables) {mapTables.put(User.class,userGreenTableManager);mapTables.put(User01.class, user01GreenTableManager);}
}
六、在Application的onCreate中初始化DevRing和配置上面创建的数据库管理者(GreenDBManager )
public class MainApplication extends Application
{@Overridepublic void onCreate() {super.onCreate();//初始化DecRing框架DevRing.init(this);System.out.println("=======================配置数据库管理者开始==============================================");DevRing.configureDB(new GreenDBManager());//传入GreenDao数据库的管理者System.out.println("=======================配置数据库管理者==============================================");Log.i("TAG", "onCreate: 创建执行");DevRing.dbManager().init();//创建DevRing.create();}}
七、使用
这里以插入数据和读取数据为例:
User01 user01 = new User01();user01.setUserId((long)101011);user01.setEmployeeNo("dj10101");user01.setRealName("test01");user01.setMobile("123456");user01.setCreateTime("2024-06-20");user01.setMobile("2024-06-20");user01.setSex("男");user01.setUserPhoto("1888888888");user01.setCertificateNumber("00000");user01.setEmployeeNo("10001");//插入一条用户数据DevRing.tableManager(User01.class).insertOne(user01);//获取全部用户数据String user01Sql = "select * from USER01";List list = DevRing.tableManager(User01.class).queryBySQL(user01Sql, null);
相关文章:

Android使用DevRing框架搭建数据库实体类以及使用
一、引用DevRing依赖 //导入DevRing依赖implementation com.ljy.ring:devring:1.1.8创建数据库表的依赖implementation org.greenrobot:greendao:3.2.2 // add libraryimplementation org.greenrobot:greendao-generator:3.0.0 二、修改工程目录下的.idea->gradle.xml文件&…...
高效BUG管理:定级、分类和处理流程
高效BUG管理:定级、状态跟踪与处理全流程 前言一、BUG的定义二、BUG的定级三、BUG的状态四、BUG的处理流程1. BUG报告2. BUG确认3. BUG修复4. BUG验证5. BUG关闭 五、常见问题与解决方案六、总结 前言 在测试工作中,BUG的定级和分类是一个重要环节&…...

服务器数据恢复—raid5热备盘同步失败导致阵列崩溃如何恢复数据?
服务器存储数据恢复环境&故障: 某品牌DS5300存储,包含一个存储机头和多个磁盘柜,组建了多组RAID5磁盘阵列。 某个磁盘柜中的一组RAID5阵列由15块数据盘和1块热备硬盘组建。该磁盘柜中的某块硬盘离线,热备盘自动替换并开始同步…...

Ubuntu iso 镜像下载 步骤截图说明
Ubuntu镜像下载,在这个网址: Enterprise Open Source and Linux | Ubuntu 步骤如下图所示: 1、登入网址 2、点击Get Ubuntu 3、点击Download Ubuntu Desktop 后续点击Downloadload 24.04 LTS直接下载就行 如果需要下载其它版本…...

git拉取gitee项目到本地
git安装等不做赘述。 根据需要选择不同操作 1.只是单纯拉取个项目,没有后续的追踪等操作 不需要使用git init初始化本地文件夹 新建一个文件夹用于存储项目,右键选择 git bash here 会出现命令行窗口 如果像我一样,只是拉取个项目作业&…...
力扣42.接雨水
力扣42.接雨水 前后缀数组 对于每个一个位置 求其前面最高高度pre_max[i] max(pre_max[i-1] , h[i])和后面最高高度suf_max[i] max(suf_max[i1] , h[i])当前i处的水容量 为min(pre_max[i] , suf_max[i]) - h[i] class Solution {public:int trap(vector<int>& …...
国产数据库与MYSQL兼容性?开发应该怎么选择?
国产数据库主要包括以下几种: TiDB:由 PingCAP 公司研发设计的开源分布式 HTAP (Hybrid Transactional and Analytical Processing) 数据库,兼容 MySQL,支持无限的水平扩展,具备强一致性和高可用等特性。 华为GaussDB…...
Spring框架中Bean的生命周期
Bean的生命周期通常指的是从创建到初始化,经过一系列的流程,最终销毁的过程。只不过,在Spring框架中,Bean的生命周期是由Spring IOC容器来管理的。在Spring中,我们定义Bean时,也可以自己指定初始化和销毁的…...
从零到一学FFmpeg:avformat_alloc_output_context2 函数详析与实战
文章目录 前言一、函数原型二、功能描述三、使用场景四、AVFormatContext 结构体五、代码实例 前言 avformat_alloc_output_context2 是FFmpeg库中的一个函数,用于为输出多媒体文件初始化一个AVFormatContext结构体。这个函数在开始输出音频、视频数据到文件之前被…...
Lua 绕过元表
Lua 绕过元表,直接访问 table 的字段。 绕过元表 rawset(table, index, value),在不触发元方法的情况下,设置 table[index] 的值为 value。 rawget(table, index),在不触发元方法的情况下,获取 table[index] 的值。…...
pip方法总结(极简快速掌握)
pip是Python的包管理工具,它允许用户从PyPI等源安装和管理额外的库和依赖。以下是关于pip使用方法的详细总结,同时附上代码演示: 一、pip的基本功能 安装包:使用pip install 包名命令可以安装指定的Python包。例如,要…...
aigc基础概念(一)
目录 一、AI 1.1、基本术语 1、Artificial Intelligence (AI) —— 人工智能 2、Generative AI —— 生成性人工智能 3、Machine Learning (ML) —— 机器学习 4、Deep Learning (DL) —— 深度学习 5、Large Language Model (LLM) —— 大型语言模型 6、Transformers …...
USB学习——12、usb初始化和插拔驱动软件流程大致框架描述
usb初始化和插拔驱动软件流程大致框架描述: 当设备启动时,usb的主机控制器设备驱动(HCD)和 usb的root hub会先初始化: 1、xhci-plat.c主机控制器驱动那里,__usb_creat_hcd创建usb主机数据结构,m…...

【ARMv8/ARMv9 硬件加速系列 2.4 -- ARM NEON Q寄存器与V寄存器的关系】
文章目录 Q 与 V 的关系向量寄存器 v 的使用赋值操作寄存器赋值总结Q 与 V 的关系 在ARMv8/v9架构中,v寄存器和q寄存器实际上是对相同的物理硬件资源的不同称呼,它们都是指向ARM的SIMD(单指令多数据)向量寄存器。这些寄存器用于高效执行向量和浮点运算,特别是在多媒体处理…...

Oracle中递归查询(START WITH……CONNECT BY……)
一、基本语法 在Oracle中START WITH……CONNECT BY……一般用来查找存在父子关系的数据,也就是树形结构的数据。 SELECT * FROM TABLE WHERE 条件3 START WITH 条件1 CONNECT BY 条件2;start with [condition]:设置起点,用来限制第一层的数…...

【云原生|K8S系列】如何创建Kubernetes job和Cronjobs 入门指南
本kubernetes教程解释了如何创建kubernetes作业和cronjobs,以及它的基础知识、用例和一些提示和技巧。 什么是Kubernetes Job? Kubernetes job和cronjob是Kubernetes对象,主要用于短期和批处理工作负载。 kubernetes作业对象基本上部署了一个pod&…...

力扣每日一题 6/23 字符串/模拟
博客主页:誓则盟约系列专栏:IT竞赛 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ 520.检测大写字母【简单】 题目: 我们定义,在以下…...

Google trend搜索关键词
Google trend地址:https://trends.google.com/trends/?geoUS&hlzh-CN 1、具体的操作步骤如下: 2、Google trend搜索页面如下:...

Unity C#调用Android,IOS震动功能
最近在Unity上需要很原生移动端进行交互, 原理:新建一个android项目,把生成的app module给干掉,然后留下一个vibrationPlugin module,在这个module下写android震动代码,将这个android工程构建出来的 aar移…...
Ruby 注释
Ruby 注释 在编程中,注释是用于解释代码如何工作以及为什么这样编写的重要工具。Ruby作为一种解释型、面向对象的脚本语言,提供了灵活的注释方式,帮助开发者更好地组织和理解代码。本文将详细介绍Ruby中的注释类型、用法以及最佳实践。 Rub…...

龙虎榜——20250610
上证指数放量收阴线,个股多数下跌,盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型,指数短线有调整的需求,大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的:御银股份、雄帝科技 驱动…...

Opencv中的addweighted函数
一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...

转转集团旗下首家二手多品类循环仓店“超级转转”开业
6月9日,国内领先的循环经济企业转转集团旗下首家二手多品类循环仓店“超级转转”正式开业。 转转集团创始人兼CEO黄炜、转转循环时尚发起人朱珠、转转集团COO兼红布林CEO胡伟琨、王府井集团副总裁祝捷等出席了开业剪彩仪式。 据「TMT星球」了解,“超级…...

tree 树组件大数据卡顿问题优化
问题背景 项目中有用到树组件用来做文件目录,但是由于这个树组件的节点越来越多,导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多,导致的浏览器卡顿,这里很明显就需要用到虚拟列表的技术&…...

10-Oracle 23 ai Vector Search 概述和参数
一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI,使用客户端或是内部自己搭建集成大模型的终端,加速与大型语言模型(LLM)的结合,同时使用检索增强生成(Retrieval Augmented Generation &#…...

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)
考察一般的三次多项式,以r为参数: p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]; 此多项式的根为: 尽管看起来这个多项式是特殊的,其实一般的三次多项式都是可以通过线性变换化为这个形式…...

如何更改默认 Crontab 编辑器 ?
在 Linux 领域中,crontab 是您可能经常遇到的一个术语。这个实用程序在类 unix 操作系统上可用,用于调度在预定义时间和间隔自动执行的任务。这对管理员和高级用户非常有益,允许他们自动执行各种系统任务。 编辑 Crontab 文件通常使用文本编…...
站群服务器的应用场景都有哪些?
站群服务器主要是为了多个网站的托管和管理所设计的,可以通过集中管理和高效资源的分配,来支持多个独立的网站同时运行,让每一个网站都可以分配到独立的IP地址,避免出现IP关联的风险,用户还可以通过控制面板进行管理功…...

android13 app的触摸问题定位分析流程
一、知识点 一般来说,触摸问题都是app层面出问题,我们可以在ViewRootImpl.java添加log的方式定位;如果是touchableRegion的计算问题,就会相对比较麻烦了,需要通过adb shell dumpsys input > input.log指令,且通过打印堆栈的方式,逐步定位问题,并找到修改方案。 问题…...

【Linux系统】Linux环境变量:系统配置的隐形指挥官
。# Linux系列 文章目录 前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变量的生命周期 四、环境变量的组织方式五、C语言对环境变量的操作5.1 设置环境变量:setenv5.2 删除环境变量:unsetenv5.3 遍历所有环境…...