`
lym6520
  • 浏览: 705756 次
  • 性别: Icon_minigender_1
  • 来自: 福建
社区版块
存档分类
最新评论

这样设计dao合理吗?大家讨论讨论!(修改版)

阅读更多

这是我设计的dao的类图,我想通过这样的设计(如下图),已经可以实现单一dao的功能。

  • 大小: 18.9 KB
分享到:
评论
8 楼 inroroc 2009-07-08  
发到我邮箱即可,再次万分感谢

inroroc@163.com
7 楼 inroroc 2009-07-08  
能否将代码共享一下?万分感谢...
6 楼 lym6520 2009-07-08  
show一下AbstractBaseDao的代码:
import java.io.Serializable;
import java.util.Collection;
import java.util.List;
import org.hibernate.type.Type;
import org.springframework.dao.DataAccessException;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

import cn.f3.db.entity.AbstractHandleObj;

/**
 * 基础Dao接口,定义通用的操作
 * @author 08374
 * @version v2.4 2009/07/07
 *
 */
public abstract class AbstractBaseDao extends HibernateDaoSupport {
		
	/*对返回list进行定义,返回记录数,0不起作用*/
	private int top = 0;	
	
	public int getTop() {
		return top;
	}
	public void setTop(int top) {
		this.top = top;
	}

	/**
	 * 对于返回列表的方法,通过调用我来实现返回记录数的控制,
	 * 设置返回记录数,如若top为0不设置,使用完将top归0
	 */
	protected void setMaxResult() throws DataAccessException{
		if(this.getTop() > 0){
			getHibernateTemplate().setMaxResults(this.getTop());
			this.setTop(0);
		}
		
	}
	
	/**
	 * 保存AbstractHandleObj实体
	 * @param hobj 继承AbstractHandleObj抽象类的实体
	 * @return Serializable 主键
	 */
	public abstract Serializable save(AbstractHandleObj hobj) throws DataAccessException;
	
	/**
	 * 更新AbstractHandleObj实体
	 * @param hobj 继承AbstractHandleObj抽象类的实体
	 * @return 
	 */
	public abstract void update(AbstractHandleObj hobj) throws DataAccessException;
	
	/**
	 * 保存或更新AbstractHandleObj实体
	 * @param hobj 继承AbstractHandleObj抽象类的实体
	 */
	public abstract void saveOrUpdate(AbstractHandleObj hobj) throws DataAccessException;
	
	/**
	 * 保存或跟新实体集合Collection<AbstractHandleObj>
	 * 若实体已经存(根据主键判断)在则更新实体,则保存实体
	 * @param hobjList 继承AbstractHandleObj抽象类的实体集合
	 */
	public abstract void saveOrUpdateAll(Collection<AbstractHandleObj> hobjList)
	throws DataAccessException;
	
	/**
	 * 删除AbstractHandleObj实体
	 * @param hobj 继承AbstractHandleObj抽象类的实体
	 * @return
	 */
	public abstract void delete(AbstractHandleObj hobj)
		throws DataAccessException;
	
	/**
	 * 删除Collection<AbstractHandleObj>集合实体
	 * @param hobjList 继承AbstractHandleObj抽象类的实体集合
	 */
	public abstract void deleteAll(Collection<AbstractHandleObj> hobjList)
		throws DataAccessException;

	/**
	 * 根据主键值获得继承AbstractHandleObj的实体
	 * @param entityName 继承AbstractHandleObj抽象类的实体名称(注:包含包名)
	 * @param id 实体主键
	 * @return
	 */
	public abstract AbstractHandleObj findByID(String entityName, String id)
		throws DataAccessException;

/**略...*/
}
5 楼 kunee 2009-07-08  
标题党。。。。
4 楼 lym6520 2009-07-08  
我这个是基于Hibernate实现的
3 楼 zhangde 2009-07-08  
package com.market.b2c.suport.util.dao;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

/**
* 属性查找器
* author: zhangde
* date:   Jul 5, 2009
*/
public class PropertyFinder implements Finder {
private Class cls;
private Map<String,Object> parameters;
private Map<String,Short> comparators;
public PropertyFinder(Class cls){
this.cls=cls;
}
public void addParameter(String name,Object value){
if(parameters==null)
parameters=new HashMap();
parameters.put(name, value);
}
public void addParameter(String name,Object value,short comparator){
if(parameters==null)
parameters=new HashMap();
parameters.put(name, value);
comparators.put(name, new Short(comparator));
}

@Override
public Map<String,Object> getParameters() {
return parameters;
}
@Override
public String getSql() {
StringBuffer sql=new StringBuffer("select * from ").append(cls.getSimpleName()).append(" where 1=1");
Iterator iterator=parameters.keySet().iterator();
while(iterator.hasNext()){
String propertyName=(String) iterator.next();
Short comparator=null;
if(comparators!=null)
comparator=comparators.get(propertyName);
sql.append(" and ").append(propertyName).append(conversionComparator(comparator)).append(" ? ");
}
return sql.toString();
}

private String conversionComparator(Short comparator){
if(comparator==null || comparator==Finder.EQ)
return " = ";
if(comparator.shortValue()==Finder.GT)
return " > ";
if(comparator.shortValue()==Finder.LS)
return " < ";
return null;
}
@Override
public Class getCls() {
return cls;
}
}
2 楼 zhangde 2009-07-08  
基于JDBC实现的
1 楼 zhangde 2009-07-08  
发个我写的通用Dao 交流下



package com.market.b2c.suport.util.dao;

import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import com.market.b2c.domain.commodity.Commodity;
import com.market.b2c.suport.db.DBFactory;

/**
* description
* author: zhangde
* date: Jul 3, 2009
*/
public class BaseDaoJdbcImpl implements BaseDao {
private Connection conn;
private PreparedStatement ps;
private ResultSet rs;
public void save(Object object) {
StringBuffer sql = new StringBuffer("insert into ").append(object
.getClass().getSimpleName().toLowerCase());// 表名对应类名
sql.append(" (");
Field[] fields = object.getClass().getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
sql.append(fields[i].getName()).append(",");
}
sql.deleteCharAt(sql.length() - 1);
sql.append(") values (");
for (int i = 0; i < fields.length; i++) {
sql.append("?,");
}
sql.deleteCharAt(sql.length() - 1);
sql.append(")");
System.out.println(sql.toString());
conn = DBFactory.getConnection();
try {
ps = conn.prepareStatement(sql.toString());
for (int i = 0; i < fields.length; i++) {
Object value = null;
String methodName = "get"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Method method = object.getClass().getMethod(methodName, null);
value = method.invoke(object, null);
ps.setObject(i + 1, value);
}
ps.execute();
} catch (Exception e) {
e.printStackTrace();
}
}

public static void main(String[] args) {
// Commodity commodity = new Commodity();
// //commodity.setId(new Integer(2));
// commodity.setName("commodity1");
BaseDao baseDao = new BaseDaoJdbcImpl();
// baseDao.save(commodity);
//
// Commodity commdoity2=(Commodity) baseDao.get(Commodity.class, new Integer(2));
// System.out.println(commdoity2.getName());
// System.out.println(commdoity2.getId());
//baseDao.delete(Commodity.class, new Integer(2));
// Commodity commodity=(Commodity) baseDao.getByProperty(Commodity.class, "name", "commodity1");
// System.out.println(commodity.getName());
// System.out.println(commodity.getId());
// List list=baseDao.findByProperty(Commodity.class, "name", "commodity1");
// System.out.println(list.size());
PropertyFinder finder=new PropertyFinder(Commodity.class);
finder.addParameter("name", "commodity1");
finder.addParameter("id", new Integer(30));
List list=baseDao.find(finder);
System.out.println(list.size());
}

public Object get(Class cls,Integer id) {
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where id=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setInt(1, id.intValue());
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(object!=null)
throw new Exception("主键不唯一!");
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String field=fields[i].getName();
String methodName="set"+ field.substring(0, 1).toUpperCase()+ field.substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(rs.findColumn(field))});
}
}
} catch (Exception e) {
e.printStackTrace();
}
return object;
}

public void delete(Class cls, Integer id) {
String sql="delete from " + cls.getSimpleName().toLowerCase()+" where id=?";
conn = DBFactory.getConnection();
try{
ps = conn.prepareStatement(sql.toString());
ps.setInt(1, id.intValue());
int row=ps.executeUpdate();
System.out.println(sql);
if(row==0)
throw new Exception("删除的行为0!");
}catch(Exception e){
e.printStackTrace();
}
}

public Object getByProperty(Class cls, String propertyName, Object value) {
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where "+propertyName+"=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setObject(1, value);
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(object!=null)
throw new Exception("主键不唯一!");
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){

String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
}
} catch (Exception e) {
e.printStackTrace();
}
return object;
}

public List findByProperty(Class cls, String propertyName, Object value) {
List result=null;
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where "+propertyName+"=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setObject(1, value);
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(result==null)
result=new ArrayList();
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
result.add(object);
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}

@Override
public List find(Finder finder) {
List result=null;
conn = DBFactory.getConnection();
Field[] fields = finder.getCls().getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(finder.getSql());
Map parameters=finder.getParameters();
Iterator iterator=parameters.keySet().iterator();
int k=1;
while(iterator.hasNext()){
String propertyName=(String) iterator.next();
ps.setObject(k++, parameters.get(propertyName));
System.out.println( parameters.get(propertyName));
}
System.out.println(finder.getSql());
rs=ps.executeQuery();

while(rs.next()){
if(result==null)
result=new ArrayList();
Class clstmp=Class.forName(finder.getCls().getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=finder.getCls().getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
result.add(object);
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}

相关推荐

    2概要设计1

    《码农聊天网站概要设计》 ...综上所述,码农聊天网站的设计综合考虑了功能需求、性能优化、安全性以及用户体验,采用成熟的技术栈和合理的架构设计,以期构建一个高效、安全、用户友好的在线交流平台。

    通讯录系统文档(初期设计)

    ### 通讯录系统文档(初期设计)知识点梳理 #### 一、项目背景及意义 - **背景**: 随着现代社会人际交往的增加,管理个人联系信息变得日益重要。传统的纸质通讯录已不能满足现代人的需求,特别是在频繁出差的情况...

    关于一些数据库的资料,看看吧!看看吧!对各位有好处的啊!

    7. **数据库设计**:涉及数据库的结构设计,包括关系模型,以及如何根据业务需求进行合理的数据库表设计。 8. **安全性**:介绍了如何设置访问控制,保护数据库免受未经授权的访问。 9. **数据备份与恢复**:讲解...

    软件的技术方案设计完整版.docx

    【软件的技术方案设计完整版.docx】文档详细阐述了一个基于JavaEE技术的软件开发方案,主要涉及以下几个核心知识点: 1. **开发框架与体系结构**: - 本方案采用B/S架构,允许系统集中部署并分布式使用,便于升级...

    设计健壮的关系数据库持久层

    文档中的设计部分详细讨论了持久层的设计要素: 1. **总体设计**:从高层次上概述了持久层的组成部分及其相互作用。 2. **具体类的设计**:每个类的作用和其实现细节,如持久对象类如何封装数据库记录的状态。 3. *...

    基于ssm+mysql教师管理信息系统源码数据库论文.doc

    本文将详细讨论如何利用SSM框架和MySQL数据库设计并实现一个教师管理信息系统。教师信息管理是学校日常运营的关键部分,包括教师基本信息、课程安排、考核评价、奖励惩罚等多个方面。传统的管理方式往往效率低下,而...

    JAVA 窗体系统

    在这个特定的场景中,我们讨论的是一个基于Java的学生成绩管理系统,它利用了GUI窗体来交互并管理学生数据,并且依赖MySQL数据库来存储和操作这些数据。下面我们将深入探讨相关的知识点。 1. **Java GUI**: - **...

    基于SSH的BBS论坛

    【基于SSH的BBS论坛】是一个使用Struts2、Spring和Hibernate三大框架构建的网络社区应用。SSH(Struts2、Spring、Hibernate)是Java ...通过合理设计和不断优化,这样的论坛能为用户提供稳定、高效、安全的交流平台。

    Spring Security 2.0.x完全中文参考文档

    Session固定是一种常见的攻击手段,通过合理的配置可以有效防止此类攻击的发生。 **2.4. 保护方法** - **2.4.1. 元素** `&lt;global-method-security&gt;`标签可以用来全局地启用方法级别的安全性检查。 - **2.4.1.1...

    myeclipse7.1Gen的写法

    通常,Gen工具支持自定义模板,可以用于生成如实体类(Entity)、数据访问对象(DAO)、服务层接口和服务实现(Service Interface & Implementation)、控制器(Controller)等不同层次的代码。此外,它还能根据...

    如何学习mysql绝对经典

    - **数据库设计**:了解ER模型(实体-关系模型)和范式理论,用于创建合理、高效的数据库结构。 2. **MySQL安装与配置** - **下载与安装**:访问MySQL官网下载适合操作系统的版本,并按照指引完成安装。 - **...

Global site tag (gtag.js) - Google Analytics