`
mabusyao
  • 浏览: 254723 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

IBaseDao的设计

阅读更多
去网上查了下,发现泛型Dao的设计比较热门,比较起来也相对通用。

只是因为还没有用上hibernate,所以做了些修改,不提供BaseDao的默认实现(如果是hibnerate下,很多实现可以在一个抽象类里面实现)。

2009-09-09 更新 : 修改了几个方法的返回类型, 添加了一个查询方法。开始感到这个框架的问题, 用了好几个Object 类型的参数了。思考下后面应该怎么改。
package shopping.ibm.dao;

import java.sql.Connection;
import java.util.ArrayList;
import java.util.List;

/**
 * Provide basic dao operations.
 * 
 * @author yaoh
 *
 * @param <T, I>
 */
public interface IBaseDao<T, I> {

	/**
	 * Get database connection.
	 * 
	 * @return available database cnnection.
	 */
	public Connection getConnection(); 
	
	/**
	 * Release database connection.
	 * 
	 */
	public void releaseConnection(Connection conn);
	
	/**
	 * Get data count based on sql.
	 * 
	 * @param sql
	 * @return total count.
	 */
    public int getTotalCount();
    
    /**
     * Create an object.
     * @param t
     * @return positive id if create successfully.
     */
	public long create(T t);
	
	/**
	 * Update an object.
	 * @param t
	 * @return positive id if create successfully.
	 */
	public int update(T t);
	
	/**
	 * Delete an object.
	 * @param t
	 * @return delete successfully.
	 */
	public boolean delete(T t);
	
	/**
	 * Delete by id.
	 * @param id
	 * @return delete successfully.
	 */
	public boolean deleteById(I id);
	
	/**
	 * batch delete by id.
	 * @param id
	 * @return result of each delete.
	 */
	public void batchDeleteById(I[] ids); 
	
	/**
	 * batch delete by object.
	 * @param ts
	 * @return result of each delete.
	 */
	public void batchDelete(T[] ts);
	
	
	/**
	 * find T by id.
	 * @param id
	 * @return query result.
	 */
	public T findById(I id);
	
	/**
	 * find by primary key.(name....)
	 * @param keyName
	 * @param keyValue
	 * @return
	 */
	public T findByPk(String keyName, Object keyValue); 
	
	/**
	 * find by key.
	 * @param keyNames
	 * @param keyValues
	 * @return
	 */
	public List<T> findByKey(String[] keyNames, Object[] keyValues);
	
	/**
	 * find by sql.
	 * @param strsql
	 * @return
	 */
	public List<T> findBySql(String sql);
	
	/**
	 * Excute sql directly.
	 * @param strsql
	 * @return is sql successfully.
	 */
	public boolean excuteSql(String sql);

	/**
	 * Update user with id set keyNames = keyValues
	 * @param id
	 * @param keyNames
	 * @param keyValues
	 * @return if update successfully.
	 */
	public int update(long id, ArrayList<String> keyNames, ArrayList<Object> keyValues);
}

分享到:
评论

相关推荐

    基于EJB架构的论坛系统设计PPT课件.pptx

    同时,设计了相应的数据访问接口(IBaseDao及各个实体的Dao接口)和业务逻辑接口(IBbsUserService等),用于定义操作这些实体的方法。 数据访问层的实现,首先实现了BaseDao基类,然后各个实体的Dao类继承自...

    元数据详细设计.docx

    `BaseDAO`可能是一个基础DAO类,`sortBaseDAO`和`IBaseDAO`则可能表示排序功能和DAO接口,它们实现了`findViewsByParentId`方法,返回视图列表。 在视图的展示方面,有多个JSP页面如`views_manage.jsp`、`views_...

    Hibernate留言板

    根据提供的信息,我们可以总结出以下相关的IT知识点,主要聚焦于Hibernate框架的应用以及系统设计: ### Hibernate框架基础 **1. Hibernate简介:** - **定义:** Hibernate是一种面向Java环境的对象关系映射...

    java 基于泛型与反射的通用 DAO

    最后,“IBaseDao.java”可能是`BaseDao`的接口定义,它声明了一些通用的DAO操作,如`save`, `findById`等,以便于子类实现或继承。这样做的好处是提高了代码的可扩展性和模块化。 综上所述,这个项目展示了如何...

    数据库导入和实现的方法

    public interface IUserDao extends IBaseDao, Integer&gt; { public abstract void insert(List&lt;User&gt; list); } ``` #### 2. UserDaoImpl实现 `UserDaoImpl`实现了`IUserDao`接口,并提供了具体的实现逻辑。 ```...

    SSH框架搭建

    1. **Struts**:这是一个基于MVC(Model-View-Controller)设计模式的Web应用框架,负责处理HTTP请求和控制应用程序流程。在Struts中,Action类是业务逻辑的载体,而配置文件struts-config.xml定义了请求与Action的...

    AndroidSqlite数据库操作封装SQLiteUtils.zip

    IBaseDao userDAO = DaoFactory.createGenericDao(dbSqlite, UserModel.class);3. 创建表:userDAO.createTable(); 4. Insert 记录:UserModel user = new UserModel(); user.userName = "darcy"; user....

    Struts+Spring+Hibernate开发实例.pdf

    - **IBaseDao** 是自定义的基础数据访问接口,文档中提到的这个接口定义了打开Session的方法以及执行HQL查询的抽象方法,具体实现可以根据不同的数据访问技术来完成。 **Hibernate框架** Hibernate是一个面向Java...

    DAO.rar_Java编程_Java_

    7. **IBaseDao.java**:接口,定义了DAO的基本操作,如查询、添加、更新和删除数据。实现了这个接口的类将具体实现数据库操作逻辑。 8. **DriverDataPojo.java**:数据驱动POJO(Plain Old Java Object),通常代表...

    使用配置文件对DAO层封装具有分页功能的S2SH整合实例_好资源0分送

    本文档中的DAO层封装是指通过特定的设计模式和技术手段(如泛型、抽象类等),使得DAO层的实现更为通用和灵活。 2. **分页功能**: 在Web应用中,为了提高用户体验和系统性能,通常会采用分页技术来展示大量数据。...

Global site tag (gtag.js) - Google Analytics