当前位置: 首页 > news >正文

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管理&#xff1a;定级、状态跟踪与处理全流程 前言一、BUG的定义二、BUG的定级三、BUG的状态四、BUG的处理流程1. BUG报告2. BUG确认3. BUG修复4. BUG验证5. BUG关闭 五、常见问题与解决方案六、总结 前言 在测试工作中&#xff0c;BUG的定级和分类是一个重要环节&…...

服务器数据恢复—raid5热备盘同步失败导致阵列崩溃如何恢复数据?

服务器存储数据恢复环境&故障&#xff1a; 某品牌DS5300存储&#xff0c;包含一个存储机头和多个磁盘柜&#xff0c;组建了多组RAID5磁盘阵列。 某个磁盘柜中的一组RAID5阵列由15块数据盘和1块热备硬盘组建。该磁盘柜中的某块硬盘离线&#xff0c;热备盘自动替换并开始同步…...

Ubuntu iso 镜像下载 步骤截图说明

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

git拉取gitee项目到本地

git安装等不做赘述。 根据需要选择不同操作 1.只是单纯拉取个项目&#xff0c;没有后续的追踪等操作 不需要使用git init初始化本地文件夹 新建一个文件夹用于存储项目&#xff0c;右键选择 git bash here 会出现命令行窗口 如果像我一样&#xff0c;只是拉取个项目作业&…...

力扣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兼容性?开发应该怎么选择?

国产数据库主要包括以下几种&#xff1a; TiDB&#xff1a;由 PingCAP 公司研发设计的开源分布式 HTAP (Hybrid Transactional and Analytical Processing) 数据库&#xff0c;兼容 MySQL&#xff0c;支持无限的水平扩展&#xff0c;具备强一致性和高可用等特性。 华为GaussDB…...

Spring框架中Bean的生命周期

Bean的生命周期通常指的是从创建到初始化&#xff0c;经过一系列的流程&#xff0c;最终销毁的过程。只不过&#xff0c;在Spring框架中&#xff0c;Bean的生命周期是由Spring IOC容器来管理的。在Spring中&#xff0c;我们定义Bean时&#xff0c;也可以自己指定初始化和销毁的…...

从零到一学FFmpeg:avformat_alloc_output_context2 函数详析与实战

文章目录 前言一、函数原型二、功能描述三、使用场景四、AVFormatContext 结构体五、代码实例 前言 avformat_alloc_output_context2 是FFmpeg库中的一个函数&#xff0c;用于为输出多媒体文件初始化一个AVFormatContext结构体。这个函数在开始输出音频、视频数据到文件之前被…...

Lua 绕过元表

Lua 绕过元表&#xff0c;直接访问 table 的字段。 绕过元表 rawset(table, index, value)&#xff0c;在不触发元方法的情况下&#xff0c;设置 table[index] 的值为 value。 rawget(table, index)&#xff0c;在不触发元方法的情况下&#xff0c;获取 table[index] 的值。…...

pip方法总结(极简快速掌握)

pip是Python的包管理工具&#xff0c;它允许用户从PyPI等源安装和管理额外的库和依赖。以下是关于pip使用方法的详细总结&#xff0c;同时附上代码演示&#xff1a; 一、pip的基本功能 安装包&#xff1a;使用pip install 包名命令可以安装指定的Python包。例如&#xff0c;要…...

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初始化和插拔驱动软件流程大致框架描述&#xff1a; 当设备启动时&#xff0c;usb的主机控制器设备驱动&#xff08;HCD&#xff09;和 usb的root hub会先初始化&#xff1a; 1、xhci-plat.c主机控制器驱动那里&#xff0c;__usb_creat_hcd创建usb主机数据结构&#xff0c;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……一般用来查找存在父子关系的数据&#xff0c;也就是树形结构的数据。 SELECT * FROM TABLE WHERE 条件3 START WITH 条件1 CONNECT BY 条件2;start with [condition]&#xff1a;设置起点&#xff0c;用来限制第一层的数…...

【云原生|K8S系列】如何创建Kubernetes job和Cronjobs 入门指南

本kubernetes教程解释了如何创建kubernetes作业和cronjobs&#xff0c;以及它的基础知识、用例和一些提示和技巧。 什么是Kubernetes Job? Kubernetes job和cronjob是Kubernetes对象&#xff0c;主要用于短期和批处理工作负载。 kubernetes作业对象基本上部署了一个pod&…...

力扣每日一题 6/23 字符串/模拟

博客主页&#xff1a;誓则盟约系列专栏&#xff1a;IT竞赛 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 520.检测大写字母【简单】 题目&#xff1a; 我们定义&#xff0c;在以下…...

Google trend搜索关键词

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

Unity C#调用Android,IOS震动功能

最近在Unity上需要很原生移动端进行交互&#xff0c; 原理&#xff1a;新建一个android项目&#xff0c;把生成的app module给干掉&#xff0c;然后留下一个vibrationPlugin module&#xff0c;在这个module下写android震动代码&#xff0c;将这个android工程构建出来的 aar移…...

Ruby 注释

Ruby 注释 在编程中&#xff0c;注释是用于解释代码如何工作以及为什么这样编写的重要工具。Ruby作为一种解释型、面向对象的脚本语言&#xff0c;提供了灵活的注释方式&#xff0c;帮助开发者更好地组织和理解代码。本文将详细介绍Ruby中的注释类型、用法以及最佳实践。 Rub…...

龙虎榜——20250610

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

Opencv中的addweighted函数

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

转转集团旗下首家二手多品类循环仓店“超级转转”开业

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

tree 树组件大数据卡顿问题优化

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

10-Oracle 23 ai Vector Search 概述和参数

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

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)

考察一般的三次多项式&#xff0c;以r为参数&#xff1a; p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]&#xff1b; 此多项式的根为&#xff1a; 尽管看起来这个多项式是特殊的&#xff0c;其实一般的三次多项式都是可以通过线性变换化为这个形式…...

如何更改默认 Crontab 编辑器 ?

在 Linux 领域中&#xff0c;crontab 是您可能经常遇到的一个术语。这个实用程序在类 unix 操作系统上可用&#xff0c;用于调度在预定义时间和间隔自动执行的任务。这对管理员和高级用户非常有益&#xff0c;允许他们自动执行各种系统任务。 编辑 Crontab 文件通常使用文本编…...

站群服务器的应用场景都有哪些?

站群服务器主要是为了多个网站的托管和管理所设计的&#xff0c;可以通过集中管理和高效资源的分配&#xff0c;来支持多个独立的网站同时运行&#xff0c;让每一个网站都可以分配到独立的IP地址&#xff0c;避免出现IP关联的风险&#xff0c;用户还可以通过控制面板进行管理功…...

android13 app的触摸问题定位分析流程

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

【Linux系统】Linux环境变量:系统配置的隐形指挥官

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