去网上查了下,发现泛型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);
}
分享到:
相关推荐
同时,设计了相应的数据访问接口(IBaseDao及各个实体的Dao接口)和业务逻辑接口(IBbsUserService等),用于定义操作这些实体的方法。 数据访问层的实现,首先实现了BaseDao基类,然后各个实体的Dao类继承自...
`BaseDAO`可能是一个基础DAO类,`sortBaseDAO`和`IBaseDAO`则可能表示排序功能和DAO接口,它们实现了`findViewsByParentId`方法,返回视图列表。 在视图的展示方面,有多个JSP页面如`views_manage.jsp`、`views_...
根据提供的信息,我们可以总结出以下相关的IT知识点,主要聚焦于Hibernate框架的应用以及系统设计: ### Hibernate框架基础 **1. Hibernate简介:** - **定义:** Hibernate是一种面向Java环境的对象关系映射...
最后,“IBaseDao.java”可能是`BaseDao`的接口定义,它声明了一些通用的DAO操作,如`save`, `findById`等,以便于子类实现或继承。这样做的好处是提高了代码的可扩展性和模块化。 综上所述,这个项目展示了如何...
public interface IUserDao extends IBaseDao, Integer> { public abstract void insert(List<User> list); } ``` #### 2. UserDaoImpl实现 `UserDaoImpl`实现了`IUserDao`接口,并提供了具体的实现逻辑。 ```...
1. **Struts**:这是一个基于MVC(Model-View-Controller)设计模式的Web应用框架,负责处理HTTP请求和控制应用程序流程。在Struts中,Action类是业务逻辑的载体,而配置文件struts-config.xml定义了请求与Action的...
IBaseDao userDAO = DaoFactory.createGenericDao(dbSqlite, UserModel.class);3. 创建表:userDAO.createTable(); 4. Insert 记录:UserModel user = new UserModel(); user.userName = "darcy"; user....
- **IBaseDao** 是自定义的基础数据访问接口,文档中提到的这个接口定义了打开Session的方法以及执行HQL查询的抽象方法,具体实现可以根据不同的数据访问技术来完成。 **Hibernate框架** Hibernate是一个面向Java...
7. **IBaseDao.java**:接口,定义了DAO的基本操作,如查询、添加、更新和删除数据。实现了这个接口的类将具体实现数据库操作逻辑。 8. **DriverDataPojo.java**:数据驱动POJO(Plain Old Java Object),通常代表...
本文档中的DAO层封装是指通过特定的设计模式和技术手段(如泛型、抽象类等),使得DAO层的实现更为通用和灵活。 2. **分页功能**: 在Web应用中,为了提高用户体验和系统性能,通常会采用分页技术来展示大量数据。...