在Web开发中,一般都分3层。
Controller/Action 控制层,
Service/Business 服务层/业务逻辑层,
Dao 数据访问层/数据持久层。

在学习和工作的实践过程中,我发现很多功能是比较通用的,我们可以把他们抽象成API接口。

下文通过一段较长的代码,Hibernate实现,来展示如何设计一些通用的API。

说明:代码只是起到一个示范(Demo)的作用,实际上完全可以做得更强大。
我最近已经在现在的基础上大大改进了,现在把比较基础的实现分享给大家。

package cn.fansunion.demo.db.dao; 

import java.lang.reflect.ParameterizedType;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set; import javax.annotation.Resource; import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory; import cn.fansunion.common.util.EmptyUtils; /**
* Dao的父类。采用泛型,实现了 一些通用的功能,大大减少了子类代码的重复。 * 目前只能适用于1个表或实体。
*
* @author leiwen@fansunion.cn
*/
public abstract class BaseDao<T> { private Class<T> modelClazz; @Resource
private SessionFactory sessionFactory; // ////////////////////////////////////////////////////////////// public BaseDao() {
this.modelClazz = (Class<T>) ((ParameterizedType) getClass()
.getGenericSuperclass()).getActualTypeArguments()[0];
} // //////////////////////////////////////////////////////
// //////////////////////泛型方法-CRUD/////////////////////////
// ///////////////////////////////////////////////////// /**
* 根据主键查询
*
* @param id
* 主键
* @return 实体对象
*/
public T get(Integer id) {
T entity = (T) getCurrentSession().get(modelClazz, id);
return entity;
} /**
* 增加
*
* @param entity
* 实体对象
*/
public void add(T entity) {
getCurrentSession().save(entity); } /**
* 物理删除
*
* @param entity
* 实体对象
*/
public void delete(T entity) {
getCurrentSession().delete(entity);
} /**
* 更新
*
* @param entity
* 持久态的实体对象
*/
public void update(T entity) {
getCurrentSession().update(entity);
} /**
* 逻辑删除
*
* @param id
* 主键
*/
public void remove(Integer id) { Session session = getCurrentSession();
String sql = "update " + modelClazz
+ " set isDeleted = 1 where id = :id";
Query query = session.createQuery(sql);
query.setParameter("id", id);
query.executeUpdate(); } // ///////////////////////////////////////////////
// ////////////获取记录总数/////////////////////////
// ///////////////////////////////////////////////
/**
* 获得1个整数
*
* @param hql
* hql语句
* @return 1个整数
*/
protected Integer getCount(String hql) {
Integer count = 0;
Query query = createQuery(hql);
count = getCount(query);
return count;
} protected Integer getCount(String hql, String key, Object value) {
Integer count = 0;
Query query = createQuery(hql, key, value);
count = getCount(query);
return count;
} // 带参数的hql语句
protected Integer getCount(String hql, Map<String, Object> params) {
Integer count = 0;
Query query = createQuery(hql, params);
count = getCount(query);
return count;
} private Integer getCount(Query query) {
Integer count = 0;
Object uniqueResult = query.uniqueResult();
if (uniqueResult != null) {
count = Integer.parseInt(uniqueResult.toString());
}
return count;
} // ///////////////////////////////////////////////
// ////////////获取一个对象/////////////////////////
// ///////////////////////////////////////////////
protected List findByProperty(String name, Object value) {
String hql = "from " + modelClazz.getSimpleName() + " where " + name
+ "=" + ":" + name;
return executeQueryList(hql, name, value);
} protected T executeQueryUnique(String hql) {
T result = null;
List<T> list = executeQueryList(hql);
if (list != null && list.size() >= 1) {
result = list.get(0);
}
return result;
} protected T executeQueryUnique(String hql, String key, Object value) {
Map<String, Object> params = new HashMap<String, Object>();
params.put(key, value);
return executeQueryUnique(hql, params);
} // 根据属性获得对象
protected T executeQueryUnique(String hql, String key1, Object value1,
String key2, Object value2) {
Map<String, Object> params = new HashMap<String, Object>();
params.put(key1, value1);
params.put(key2, value2);
return executeQueryUnique(hql, params);
} protected T executeQueryUnique(String hql, Map<String, Object> params) {
T result = null;
List<T> list = executeQueryList(hql, params);
if (EmptyUtils.isNotEmpty(list)) {
result = list.get(0);
}
return result;
} // ///////////////////////////////////////////////
// //////////////获取一个列表(不使用泛型 List<T>)/////////////////
// ///////////////////////////////////////////////
// 执行不带参数的hql查询,返回一个结果集List
protected List executeQueryList(String hql) {
return executeQueryList(hql, null);
} protected List executeQueryList(String hql, String key, Object value) {
Map<String, Object> params = new HashMap<String, Object>();
params.put(key, value);
return executeQueryList(hql, params);
} protected List executeQueryList(String hql, String key1, Object value1,
String key2, Object value2) {
Map<String, Object> params = new HashMap<String, Object>();
params.put(key1, value1);
params.put(key2, value2);
return executeQueryList(hql, params);
} protected List executeQueryList(String hql, Map<String, Object> params) {
return executeQueryList(hql, params, -1, -1);
} protected List executeQueryList(String hql, Integer firstResult,
Integer maxResults) {
return executeQueryList(hql, null, firstResult, maxResults);
} protected List executeQueryList(String hql, String key, Object value,
Integer firstResult, Integer maxResults) {
Map<String, Object> params = new HashMap<String, Object>();
params.put(key, value);
return executeQueryList(hql, params, firstResult, maxResults);
} // 执行带参数并且含有分页的hql查询
protected List executeQueryList(String hql, Map<String, Object> params,
Integer firstResult, Integer maxResults) {
Query query = createQuery(hql, params);
if (firstResult > 0) {
query.setFirstResult(firstResult);
} if (maxResults > 0) {
query.setMaxResults(maxResults);
} return query.list();
} // ///////////////////////////////////////////////
// ////////////更新操作/////////////////////////
// /////////////////////////////////////////////// protected int executeUpdate(String hql) {
return executeUpdate(hql, null);
} protected int executeUpdate(String hql, String key, Object value) {
Map<String, Object> params = new HashMap<String, Object>();
params.put(key, value);
return executeUpdate(hql, params);
} protected int executeUpdate(String hql, String key1, Object value1,
String key2, Object value2) {
Map<String, Object> params = new HashMap<String, Object>();
params.put(key1, value1);
params.put(key2, value2);
return executeUpdate(hql, params);
} // 执行带参数的hql更新语句
protected int executeUpdate(String hql, Map<String, Object> params) {
Query query = createQuery(hql, params);
return query.executeUpdate();
} // ///////////////////////////////////////////////
// ////////////创建Query对象/////////////////////////
// ///////////////////////////////////////////////
private Query createQuery(String hql, Map<String, Object> params) {
Query query = getCurrentSession().createQuery(hql);
if (params != null) {
Set<Entry<String, Object>> entrySet = params.entrySet();
for (Map.Entry<String, Object> entry : entrySet) {
Object value = entry.getValue();
String key = entry.getKey();
if (value instanceof Collection) {
query.setParameterList(key, (Collection) value);
} else if (value instanceof Object[]) {
query.setParameterList(key, (Object[]) value);
} else {
query.setParameter(key, value);
}
}
}
return query;
} private Query createQuery(String hql, String key, Object value) {
Query query = getCurrentSession().createQuery(hql);
if (key != null) {
query.setParameter(key, value);
}
return query;
} private Query createQuery(String hql) {
return getCurrentSession().createQuery(hql);
} /**
* 获取主数源
*/
protected Session getCurrentSession() {
return sessionFactory.getCurrentSession();
} }

在工作和学习的实践中,我发现Web开发有很大程度上的通用性。

我希望,也在努力地总结这些规律,争取早点弄出一套可以大大提高生产力的方法和代码框架。

技术不能改变程序员的命运,而生产力可以。

提高生产力,是我目前迫切的追求。

过去,现在和未来,我都将为之而努力。

我的博客网站:http://FansUnion.cn

原文参见:http://fansunion.cn/articles/2264

数据持久层(DAO)通用API的实现的更多相关文章

  1. [置顶] 数据持久层(DAO)常用功能–通用API的实现

    在Web开发中,一般都分3层. Controller/Action 控制层, Service/Business 服务层/业务逻辑层, Dao 数据访问层/数据持久层. 在学习和工作的实践过程中,我发现 ...

  2. Java数据持久层

    一.前言 1.持久层 Java数据持久层,其本身是为了实现与数据源进行数据交互的存在,其目的是通过分层架构风格,进行应用&数据的解耦. 我从整体角度,依次阐述JDBC.Mybatis.Myba ...

  3. Restful.Data v1.0 - 轻量级数据持久层组件, 正式开源发布了

    经过几个星期的优化调整,今天 Restful.Data 正式开源发布. 源码地址:https://github.com/linli8/Restful 今天不写那么多废话了,还是重新介绍一下 Restf ...

  4. Java数据持久层框架 MyBatis之背景知识一

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  5. .NET平台下,关于数据持久层框架

    在.NET平台下,关于数据持久层框架非常多,本文主要对如下几种做简要的介绍并推荐一些学习的资源: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS ...

  6. .NET开源项目介绍及资源推荐:数据持久层

    在.NET平台下,关于数据持久层框架非常多,本文主要对如下几种做简要的介绍并推荐一些学习的资源: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS ...

  7. c++ 数据持久层研究(一)

    C++ORM框架自动生成代码数据库  用过Java的都知道SSH框架,特别对于数据库开发,Java领域有无数的ORM框架,供数据持久层调用,如Hibernate,iBatis(现在改名叫MyBatis ...

  8. UWP开发之ORM实践:如何使用Entity Framework Core做SQLite数据持久层?

    选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软 ...

  9. .NET平台数据持久层框架

    在.NET平台下的几个数据持久层框架: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS.NET 5.DAAB 6.DLinq

随机推荐

  1. 《CS:APP》 chapter 9 Vitrual Memory 笔记

    Vitrual Memory In order to manage memory more efficiently and with fewer errors, modern systems prov ...

  2. 用HttpCombiner来减少js和css的请问次数

    HttpCombiner也不记得是谁写的了,功能是把多个js文件或css文件合并到一块,压缩一下一起发给客户端来优化网站. 用法是这样的: <script type="text/jav ...

  3. silverlight学习笔记——新手对silverlight的认识(1)

    这几天在搞silverlight.虽然silverlight没有前途,但始终是微软的一门技术,界面基本上与WPF共通,用一下也无妨. 学习过程并没有我原先想得那么容易,有些地方捣鼓了很久.究其原因,是 ...

  4. Codeforces Round #281 (Div. 2) D. Vasya and Chess 博弈

    D. Vasya and Chess   Vasya decided to learn to play chess. Classic chess doesn't seem interesting to ...

  5. hdu1533 费用流模板

    Going Home Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  6. pandas把多个sheet读进一个DataFrame

    #!/usr/bin/python import pandas as pd import collections df_dict = pd.read_excel('c:\data\machines.x ...

  7. String,创建对象问题

    String str=new String("aaa"); 这行代码究竟创建了几个String对象呢?答案是2个,而不是3个.由于new String("aaa" ...

  8. java 实现将java对象转为yaml文件

    首先我们建两个类,以下两个类展示的是一个学生拥有多个手机号码联系人. 先是学生类: package com.ming.yaml.beans; import java.util.ArrayList; i ...

  9. Java中final、finally、finalize的区别与用法

    1.简单区别:final用于声明属性,方法和类,分别表示属性不可交变,方法不可覆盖,类不可继承.finally是异常处理语句结构的一部分,表示总是执行.finalize是Object类的一个方法,在垃 ...

  10. 子线程更新UI

    https://www.cnblogs.com/joy99/p/6121280.html