【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

相关文章

Android Mainline基础简介

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

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

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

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt