【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

相关文章

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Java如何通过反射机制获取数据类对象的属性及方法

《Java如何通过反射机制获取数据类对象的属性及方法》文章介绍了如何使用Java反射机制获取类对象的所有属性及其对应的get、set方法,以及如何通过反射机制实现类对象的实例化,感兴趣的朋友跟随小编一... 目录一、通过反射机制获取类对象的所有属性以及相应的get、set方法1.遍历类对象的所有属性2.获取

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

Java读取InfluxDB数据库的方法详解

《Java读取InfluxDB数据库的方法详解》本文介绍基于Java语言,读取InfluxDB数据库的方法,包括读取InfluxDB的所有数据库,以及指定数据库中的measurement、field、... 首先,创建一个Java项目,用于撰写代码。接下来,配置所需要的依赖;这里我们就选择可用于与Infl