使用泛型定义一个可重用的Dao

本文详细介绍了如何在Java中利用泛型创建通用的DAO类来处理多个数据库表,通过实例演示了如何在不同场景下复用代码,提高了开发效率。同时,文章还展示了如何在使用Hibernate框架时,通过接口实现面向对象编程,并具体说明了如何定义和调用带有泛型的接口。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

dao用来和数据库进行交互,一个项目中,可能有用户表,产品表等等,不可能为每一个表都建立一个dao,使用泛型可以实现通吃。

UserDao.java

public class UserDao <T>{

    public int add(T t){
        return 0;
    }
    public int delete(int id){
        return 0;
    }
    public int delete(T t){
        return 0;
    }
    public T update(T t){
        return null;
    }
    public T findById(int id){
        return null;
    }
    public List<T> findByConditions(String where){
        return null;
    }
}

调用它:

    @Test
    public void test5(){
        UserDao<Person> dao = new UserDao<Person>();
        dao.add(new Person());
        Person result = dao.findById(1);
    }

如果使用了hibernate框架,则要实现面向接口的编程,那么怎样在接口中定义泛型呢?

IUserDao.java

public interface IUserDao <T>{
    public int add(T t);
    public int delete(int id);
    public int delete(T t);
    public T update(T t);
    public T findById(int id);
    public List<T> findByConditions(String where);
}

UserDao2.java

public class UserDao2<T> implements IUserDao<T> {

    @Override
    public int add(T t) {
        // TODO Auto-generated method stub
        return 0;
    }

    @Override
    public int delete(int id) {
        // TODO Auto-generated method stub
        return 0;
    }

    @Override
    public int delete(T t) {
        // TODO Auto-generated method stub
        return 0;
    }

    @Override
    public T update(T t) {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public T findById(int id) {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public List<T> findByConditions(String where) {
        // TODO Auto-generated method stub
        return null;
    }

}

调用方法还是和以前一样:

    @Test
    public void test6(){
        UserDao2<Person> dao = new UserDao2<Person>();
        dao.add(new Person());
        Person result = dao.findById(1);
    }

转载于:https://www.cnblogs.com/lenve/p/4518000.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值