【android开发记录片】3.数据库SQLite 的对象封装

2024-01-30 15:18

本文主要是介绍【android开发记录片】3.数据库SQLite 的对象封装,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在学习android时,做了一个简单的数据表与javaBean的映射,思路是:

定义一个Entity 的泛型抽象类,然后XXXDao 类继承于Entity,变成实体操作类,最后的bean实现序列化接口即可。

 

下面以一个“分类”为例说明一下:

首先是Entity.java的定义:

package org.nerve.cellnote.storage;import java.io.Serializable;
import java.util.ArrayList;import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;/*** @项目名称 :CellNote* @文件名称 :Entity.java* @所在包 :org.nerve.cellnote.storage* @功能描述 :*	是一个范型抽象类,模拟 JPA 形式,封装数据库的常用操作,子类必须实现如下方法以达到数据绑定:<br />*		public abstract String getDBName();	//绑定的表名  <br />*		public abstract String getCreateSQL();	//表的构造sql语句,在建表时使用  <br />*		public abstract String[] getColumns();	//表列	<br />*		public abstract T bind(Cursor c);	//实体的数据注入	<br />*	<br />* @创建者 :集成显卡	1053214511@qq.com* @创建日期 :2013-1-21* @修改记录 :*/
public abstract class Entity<T extends Serializable> {protected Context context;public Entity(Context c){context = c;}/*** @方法名称 :getDBName* @功能描述 :对应的表名* @return* @return :String*/public abstract String getDBName();/*** @方法名称 :getCreateSQL* @功能描述 :创建表的SQL* @return* @return :String*/public abstract String getCreateSQL();/*** @方法名称 :getColumns* @功能描述 :得到字段* @return* @return :String[]*/public abstract String[] getColumns();/*** @方法名称 :bind* @功能描述 :传入一个Cursor,绑定到实体中* @param c* @return :void*/public abstract T bind(Cursor c);public SQLiteDatabase getDB(){return new DBManager(context).getDB();}public T getById(int id){Cursor c = query("_id="+id, null, null, null, null);if(c.moveToFirst())return bind(c);elsereturn null;}/*** @方法名称 :getBy* @功能描述 :* *	@param column 查询的字段*	@param value	值*	@return*/public T getBy(String column, String value){Cursor c = query(column+"=?", new String[]{value}, null, null, null);if(c.moveToFirst() == false)return null;return bind(c);}/*** @方法名称 :getAll* @功能描述 :返回所有记录* *	@return*/public ArrayList<T> getAll(){Cursor c = query(null, null, null, null, getDefaultOrderBy());ArrayList<T> result = new ArrayList<T>();while(c.moveToNext()){T temp = bind(c);result.add(temp);}c.close();return result;}/*** @方法名称 :getList* @功能描述 :根据条件得到数据列表* *	@param column	匹配的字段*	@param value	字段值*	@param orderBY	排序方式*	@return*/public ArrayList<T> getList(String column, String values, String orderBY){Cursor c = query(column+"=?", new String[]{values}, null, null, orderBY);ArrayList<T> result = new ArrayList<T>();while(c.moveToNext()){T temp = bind(c);result.add(temp);}c.close();return result;}public ArrayList<T> getListLike(String where, String[] values, String orderBY){Cursor c = query(where, values, null, null, orderBY);ArrayList<T> result = new ArrayList<T>();while(c.moveToNext()){T temp = bind(c);result.add(temp);}c.close();return result;}/*** @方法名称 :query* @功能描述 :得到一个游标,数据表名和字段都是使用默认的* @param where* @param argsW* @param groupBy* @param having* @param orderBy* @return* @return :Cursor*/public Cursor query(String where, String[] argsW, String groupBy, String having, String orderBy){DBManager db = new DBManager(context);return db.getDB().query(getDBName(), getColumns(), where, argsW, groupBy, having, orderBy);}/*** @方法名称 :getDefaultOrderBy* @功能描述 :得到默认的排序方式。如果子类有特别要求,重写这个方法* @return* @return :String*/public String getDefaultOrderBy(){return null;}/*** @方法名称 :insert* @功能描述 :* @param cv* @return 返回新增数据行的id,如果出错返回-1* @return :long*/public long insert(ContentValues cv){return getDB().insert(getDBName(), null, cv);}public int update(ContentValues cv, String where, String[] whereArgs){return getDB().update(getDBName(), cv, where, whereArgs);}/*** @方法名称 :delById* @功能描述 :根据id删除数据行,返回的是删除的行数* *	@param id*	@return*/public int delById(int id){return getDB().delete(getDBName(), "_id="+id, null);}/*** @方法名称 :delBy* @功能描述 :根据条件删除数据行,返回的是删除的行数* *	@param column*	@param value*	@return*/public int delBy(String column, String value){return getDB().delete(getDBName(), column+"=?", new String[]{value});}
}


 

再定义bean : Category.java

package org.nerve.cellnote.domain;import java.io.Serializable;/*** @项目名称 :CellNote* @文件名称 :Category.java* @所在包 :org.nerve.cellnote.domain* @功能描述 :*	便签的分类* @创建者 :集成显卡	1053214511@qq.com* @创建日期 :2013-1-21* @修改记录 :*/
@SuppressWarnings("serial")
public class Category implements Serializable{public int id;public String name;public int parentId;public Category(){}public Category(String name){this.name = name;}
}


最后是CategoryDao.java:

package org.nerve.cellnote.domain;import org.nerve.cellnote.storage.Entity;import android.content.Context;
import android.database.Cursor;public class CategoryDao extends Entity<Category>{public CategoryDao(Context c) {super(c);}@Overridepublic String getDBName() {return "category";}@Overridepublic String getCreateSQL() {StringBuilder sb = new StringBuilder();sb.append("create table "+getDBName()+" (_id integer primary key autoincrement," +"name text,parentId integer);");return sb.toString();}@Overridepublic String[] getColumns() {return new String[]{"_id","name","parentId"};}/*** 在这里,使用了 getColumns()  的顺序获得数据项*/@Overridepublic Category bind(Cursor c) {Category cg = new Category();cg.id = c.getInt(0);cg.name = c.getString(1);cg.parentId = c.getInt(2);return cg;}}


DAO 类中重写指定的方法就可以了。

对于获取数据,可以这样:

CategoryDao categoryDao = new CategoryDao(context);
return getCategoryDao().getById(id);


可以将这些操作封装在一个Service层中,方便管理。

 

这篇关于【android开发记录片】3.数据库SQLite 的对象封装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os