【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

相关文章

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

Android实现悬浮按钮功能

《Android实现悬浮按钮功能》在很多场景中,我们希望在应用或系统任意界面上都能看到一个小的“悬浮按钮”(FloatingButton),用来快速启动工具、展示未读信息或快捷操作,所以本文给大家介绍... 目录一、项目概述二、相关技术知识三、实现思路四、整合代码4.1 Java 代码(MainActivi

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例