基于spring注解,泛型的使用


/**
 * Service基类,所有Service均继承该类
 *
 */
public abstract class BaseService<T> {

    /* 所有子类直接通过该SQLSession操作数据库 */
    @Resource(name = "sqlSession")
    protected SqlSession sqlSession;

    protected Class<T> clazz;

    protected  String DOMAIN_NAME;

    /* 用于记录日志 */
    protected Logger logger=null ;

    @SuppressWarnings("unchecked")
    @PostConstruct
    public void postConstruct(){ 
        try {
            Type type= this.getClass().getGenericSuperclass();
            ParameterizedType parameterizedType=(ParameterizedType) type;
            clazz= (Class<T>) parameterizedType.getActualTypeArguments()[0];
            DOMAIN_NAME =clazz.getName();
        } catch (Exception e) {
            e.printStackTrace();
            clazz=null;
        }
        logger = LoggerFactory.getLogger(this.getClass());
    }



    // base根据主键ID查询方法
    @Transactional(readOnly = true)
    public T getByID(Long id)throws Exception {
        try {
            return sqlSession.selectOne(DOMAIN_NAME + ".selectByPrimaryKey", id);
        } catch (Exception e) {
            logger.error("根据{}获取{}发生错误:{}", id, DOMAIN_NAME,e.getMessage(), e);

            throw e;
        }
    }

    // base新增方法
    @Transactional
    public void saveBase(T entity) throws Exception{
        try {
            sqlSession.insert(DOMAIN_NAME+".insertSelective",entity);
        } catch (Exception e) {
            e.printStackTrace();
            throw e;
        }
    }

    // base修改方法
    @Transactional
    public int updateBase(T entity) throws Exception{
        try{
            return sqlSession.update(DOMAIN_NAME+".updateByPrimaryKeySelective",entity);
        }catch(Exception e){
            logger.error(DOMAIN_NAME+"修改时发生错误:{}", e.getMessage(), e);
            throw e;
        }
    }

    // base删除方法
    @Transactional
    public void deleteBase(Long id) throws Exception {
        try {
            sqlSession.delete(DOMAIN_NAME + ".deleteByPrimaryKey", id);
        } catch (Exception e) {
            logger.error(DOMAIN_NAME+"删除时发生错误:{}", e.getMessage(), e);

            throw e;
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring框架可以通过依赖注入来管理对象之间的关系。泛型依赖注入是Spring 4版本引入的一个新特性,它允许我们使用泛型类型作为依赖注入的目标类型。 在Spring中,我们可以使用`@Autowired`注解来实现依赖注入。在Spring 4之前的版本中,我们只能使用具体的类型来指定注入的目标类型。但是在Spring 4中,我们可以使用泛型类型来指定注入的目标类型。 泛型依赖注入的好处之一是可以减少重复的代码。例如,我们可以定义一个通用的泛型接口或抽象类,然后在具体的类中使用泛型类型来指定依赖注入的目标类型。这样,我们可以减少重复的配置代码,并提高代码的可维护性和灵活性。 另一个好处是增加了类型安全性。使用泛型类型来指定依赖注入的目标类型可以在编译时检查类型是否匹配,避免在运行时出现类型转换错误或异常。 下面是一个示例代码,演示如何在Spring 4中使用泛型依赖注入: ```java public interface GenericDao<T> { // ... } @Component public class UserDao implements GenericDao<User> { // ... } @Service public class UserService { @Autowired private GenericDao<User> userDao; // ... } ``` 在上面的示例中,我们定义了一个泛型接口`GenericDao`,并在具体的实现类`UserDao`中使用了具体的类型`User`来指定泛型类型。然后,我们在`UserService`中使用泛型类型`User`来注入`UserDao`。 通过使用泛型依赖注入,我们可以更方便地管理依赖关系,并且减少了重复的配置代码。这是Spring 4版本引入的一个有用的特性,可以在开发中提高效率和代码质量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值