Android 数据库封装(SQLite)
Android 数据库操作(SQLite)
- Android 数据库操作(SQLite)
- 动态预览
- 使用
- 初始化
- 生成表
- 实体类
- 插入数据
- 批量插入
- 删除数据
- 删除全部
- 修改数据
- 查找(列表)
- 查找(单条)
- 条件查找(列表)
- 条件查找(单条)
- 源码
Android 数据库操作(SQLite)
数据库封装,方便使用。实现了数据库拷贝,实体类注解配置表及字段,并实现数据封装返回实体类,简化了sql编写和对游标的操作。
动态预览

使用
初始化
QuickDb dbHelper;dbHelper = new QuickDb(this, "quick_db1.db", "quick_db2.db", null, 10, this);
生成表
dbHelper.createTable(User.class);
实体类
@DBTable(name = "user")
public class User {@SQLObj(name = "id",constraints = @Constraints(primaryKey = true))private int id;@SQLObj(name = "name")private String name;@SQLObj(name = "header")private String header;private int age;private int sex;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getHeader() {return header;}public void setHeader(String header) {this.header = header;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public int getSex() {return sex;}public void setSex(int sex) {this.sex = sex;}
}
插入数据
User user = new User();user.setName("张三");user.setAge(18);dbHelper.insert(user);
批量插入
List<Member> members = new ArrayList<>();
for (int i = 1; i <= 10; i++) {Member member1 = new Member();member1.setAge(i);member1.setName("M_" + i);members.add(member1);
}
dbHelper.insertArray(members);
删除数据
User user_d = new User();
user_d.setId(2);
dbHelper.delete(user_d);
删除全部
dbHelper.deleteAll(Member.class);
修改数据
Member member = members.get(0);
member.setName("sb");
member.setAge(18);
dbHelper.modify(member);
查找(列表)
Member member1 = new Member();
member1.setId(1);
List<Member> members = dbHelper.findArray(member1);
查找(单条)
User user_t = new User();
user_t.setId(3);
User user2 = dbHelper.findOne(user_t);
条件查找(列表)
List<Member> members = new ArrayList<>();
members = dbHelper.findArray("select * from member", Member.class);
条件查找(单条)
Member member = dbHelper.findOne("select * from member", Member.class);
源码
https://gitee.com/squirrelhuan/quick-db
相关文章:
Android 数据库封装(SQLite)
Android 数据库操作(SQLite) Android 数据库操作(SQLite)动态预览使用初始化生成表实体类插入数据批量插入删除数据删除全部修改数据查找(列表)查找(单条)条件查找(列表&…...
Git从入门到起飞(详细)
Git从入门到起飞 Git从入门到起飞什么是Git?使用git前提(注册git)下载Git在Windows上安装Git在macOS上安装Git在Linux上安装Git 配置Git配置全局用户信息配置文本编辑器 创建第一个Git仓库初始化仓库拉取代码添加文件到仓库提交更改推送 Git基本操作查看提交历史比较…...
R读写parquet文件
什么是parquet文件 Apache Parquet是一个开源的,列存储的数据文件格式。 https://parquet.apache.org/ 在R里面,我们可以通过arrow包来读写它。 我们先安装一下arrow包,并加载它。 install.packages("arrow") library(arrow)读写…...
Java21 LTS版本
一、前言 除了众所周知的 JEP 之外,Java 21 还有更多内容。首先请确认 java 版本: $ java -version openjdk version "21" 2023-09-19 OpenJDK Runtime Environment (build 2135-2513) OpenJDK 64-Bit Server VM (build 2135-2513, mixed mo…...
【性能优化】虚拟懒加载(下拉滚动加载长列表)element-puls+el-table
目录 前言一、卡顿的原因?二、解决1、滚动懒加载2.官方 总结 前言 提示:这里可以添加本文要记录的大概内容: 在element-plus中,如果数据超过1k,就会感觉到明显的卡顿,应该是渲染的卡顿吧。反正我在请求回…...
一对多映射处理
8.3.1 、collection /** * 根据部门id查新部门以及部门中的员工信息 * param did * return */ Dept getDeptEmpByDid(Param("did") int did);<resultMap id"deptEmpMap" type"Dept"> <id property"did" column"did&quo…...
关于IDEA没有显示日志输出?IDEA控制台没有显示Tomcat Localhost Log和Catalina Log 怎么办?
问题描述: 原因是;CATALINA_BASE里面没有相关的文件配置。而之前学习IDEA的时候,把这个文件的位置改变了。导致,最后输出IDEA的时候,不会把日志也打印出来。 检查IDEA配置; D:\work_soft\tomcat_user\Tomcat10.0\bin 在此目录下&…...
蛇形填数 rust解法
蛇形填数。 在nn方阵里填入1,2,…,nn,要求填成蛇形。例如,n=4时方阵为: 10 11 12 1 9 16 13 2 8 15 14 3 7 6 5 4 解法如下: use std::io;fn main() {let mut buf String::new();…...
一文探索SD-WAN技术进阶后与MPLS的区别
在网络通信领域,随着云计算和大数据等新兴技术的快速发展,企业对于网络的可靠性、安全性以及带宽的需求越来越高。 SD-WAN(软件定义广域网)和MPLS(多协议标签交换)是两种不同的网络连接技术,它们…...
RocketMq(四)消息分类
一、普通消息 1、同步发送消息:指的是Producer发出⼀条消息后,会在收到MQ返回的ACK之后才发下⼀条消息。该方式的消息可靠性最高,但消息发送效率低。 二、顺序消息 三、延时消息...
ip地址怎么改网速快
在当今高度依赖互联网的时代,快速稳定的网络连接对于人们的生活和工作至关重要。然而,有时我们可能会遇到网络速度缓慢的问题。虽然更改IP地址并不能直接影响网络速度,但它可以成为改善网络连接的一种策略之一。虎观代理小二二将探讨如何通过…...
植物大战僵尸各种僵尸攻略(四)
前言 此文章为“植物大战僵尸”专栏中的011刊(2023年9月第十刊),欢迎订阅。版权所有。 注意: 1.本博客适用于pvz无名版; 2.pvz指植物大战僵尸(Plants VS Zonbies); 3.本文以耗费低做标准&am…...
main函数中两个参数的作用
一般我们在使用C语言时不太用到main函数自带的参数,因此最常见的main函数就像下面这样。 int main() {...... }上面这种main函数是省略了其形参的,C语言中规定main函数的参数只能有两个,习惯上这两个参数写为argc和argv,其中&…...
华为OD机试 - 连续字母长度 - 字符串(Java 2023 B卷 100分)
目录 专栏导读一、题目描述二、输入描述三、输出描述1、输入2、输出3、说明4、再输入5、输出6、说明 四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(…...
想要精通算法和SQL的成长之路 - 填充书架
想要精通算法和SQL的成长之路 - 填充书架 前言一. 填充书架1.1 优化 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 填充书架 原题链接 题目中有一个值得注意的点就是: 需要按照书本顺序摆放。每一层当中,只要厚度不够了,当前层最高…...
【ROS入门】ROS的核心概念
文章结构 通信机制节点(Node)——执行单元节点管理器(ROS Master)——控制中心话题通信——异步通信机制话题(Topic)消息(Message)——话题数据 服务通信——同步通信机制服务(Service) 话题和服务的区别参数(Parameter)——全局共享字典 文件系统功能包(Package&am…...
Python爬虫从端到端抓取网页
网页抓取和 REST API 简介 网页抓取是使用计算机程序以自动方式从网站提取和解析数据的过程。这是创建用于研究和学习的数据集的有用技术。虽然网页抓取通常涉及解析和处理 HTML 文档,但某些平台还提供 REST API 来以机器可读格式(如 JSON)检…...
这10款类似Stable Diffusion的ai绘图软件,你了解多少?
Stable Diffusion这款ai软件有哪些可以替代的软件?好用的类似Stable Diffusion的ai软件推荐,那么今天就跟着赞奇云工作站小编一起来看看吧。 什么是Stable Diffusion? 称为“Stable Diffusion”的文本到图像模型可以将任何文本转换为逼真、…...
部署ik分词器
部署ik分词器 案例版本:elasticsearch-analysis-ik-8.6.2 ES默认自带的分词器对中文处理不够友好,创建倒排索引时可能达不到我们想要的结果,然而IK分词器能够很好的支持中文分词 因为是集群部署,所以每台服务器中的ES都需…...
基于STM32+华为云IOT设计的智能垃圾桶
一、项目介绍 在商业街、小吃街和景区等人流密集的场所,垃圾桶的及时清理对于提供良好的游客体验至关重要。然而,传统的垃圾桶清理方式通常是定时或定期进行,无法根据实际情况进行及时响应,导致垃圾桶溢满,影响环境卫…...
零基础玩转Nunchaku FLUX.1:一键生成Ghibsky风格插画,效果惊艳
零基础玩转Nunchaku FLUX.1:一键生成Ghibsky风格插画,效果惊艳 你是不是也刷到过那些美得像梦一样的插画?那种线条温柔、色彩朦胧、仿佛带着童话滤镜的画面,一看就知道是Ghibsky风格。以前想做出这种效果,要么得苦练几…...
【deepin】通过x11vnc与xrdp实现Windows无缝远程控制deepin桌面
1. 为什么需要远程控制deepin桌面? 作为一个长期使用deepin系统的开发者,我经常遇到需要在Windows电脑上远程操作deepin桌面的场景。比如在家办公时想用Windows笔记本访问公司的deepin开发机,或者给使用deepin的朋友远程解决问题。传统的Tea…...
ESP32/ESP8266接入Ambient云平台实战指南
1. Ambient ESP32/ESP8266 库技术解析:面向嵌入式物联网的数据上云实践Ambient 是一款专为物联网设备设计的轻量级云端数据可视化服务,其核心价值在于将嵌入式终端采集的传感器数据,通过极简协议上传至云端,并自动生成实时、可配置…...
L6599A VCO工作原理深度解析:为什么你的LLC闭环仿真总是不稳定?
L6599A VCO工作原理深度解析:为什么你的LLC闭环仿真总是不稳定? 在LLC谐振变换器的设计中,闭环仿真的稳定性往往是工程师面临的最大挑战之一。许多经验丰富的电源工程师都曾遇到过这样的困境:明明按照芯片手册设计了所有外围电路&…...
IotNetESP32:面向i-ot.net平台的嵌入式物联网连接抽象库
1. 项目概述IotNetESP32 是一款专为 ESP32 平台设计的嵌入式物联网通信中间件库,其核心定位并非替代底层协议栈,而是构建在 ESP-IDF 或 Arduino-ESP32 框架之上、面向应用层的“连接抽象层”。该库通过封装 WiFi 管理、MQTT 客户端、HTTP 客户端三大基础…...
CMMI认证避坑指南:中小企业如何用最低成本拿下3级认证(附实战案例)
CMMI认证避坑指南:中小企业如何用最低成本拿下3级认证(附实战案例) 对于许多中小企业来说,CMMI认证似乎是一个遥不可及的目标——高昂的咨询费用、复杂的文档要求、漫长的准备周期,每一项都让资源有限的团队望而却步。…...
告别零样本提示:为什么在复杂业务里,Text2SQL微调才是王道?以DB-GPT-Hub为例
为什么Text2SQL微调在复杂业务场景中不可替代?DB-GPT-Hub实战解析 当企业数据库遇到多表关联、嵌套查询和业务专属术语时,传统零样本提示方法的SQL生成准确率往往会断崖式下跌。去年某金融科技团队在迁移核心交易系统时发现,即使使用顶级大模…...
ECharts甘特图实战:5步搞定项目进度可视化(附完整代码)
ECharts甘特图实战:5步搞定项目进度可视化(附完整代码) 项目管理中,清晰直观的进度展示往往能事半功倍。ECharts作为国内领先的数据可视化库,其强大的定制能力可以轻松实现专业级甘特图。本文将手把手带你从零开始&…...
Google 迎来「DeepSeek 时刻」:TurboQuant算法实现bit无损、×加速、×压缩、零预处理叭
从 UI 工程师到 AI 应用架构者 13 年前,我的工作是让按钮在 IE6 上对齐; 13 年后,我用 fetch-event-source 订阅大模型的“思维流”,用 OCR 解锁图片中的文字——前端,正在成为 AI 产品的第一道体验防线。 最近&#x…...
STGCN实战:从骨架数据到动作识别的时空建模
1. 理解STGCN的核心思想 第一次接触STGCN时,我被这个看似复杂的名字吓到了——时空图卷积网络,听起来就像是要同时处理时间和空间两个维度的数据。但当我真正拆解它的工作原理后,发现这个设计其实非常巧妙。想象一下,我们要分析一…...
