Hibernate关于JPA底层BaseDAO具体方法操作

前言:

目前主流框架springboot或者分布式的spring框架都在集成hibernate的JPA,使用方便,但是有时候又不能满足我们更多的需求,不如Mybaties更加灵活多样,或者满足我们更多的对于数据库的DDL,那么我们同样可以使用JPA的基础BaseDao实现我们更多的需求。

例如:想获取数据库中id的最大值,在值的基础上+1赋值给下一条数据的id。

/**
 * @Description TODO
 * @Author yitianRen
 * @Date 2019/8/1 15:05
 * @Version 1.0
 **/
@Component
public class SysAutotaskDao extends BaseDAO<SysAutotaskVo> implements ISysAutotaskDao {
    @PersistenceContext
    protected EntityManager entityManager;
    @Override
    public Integer getMaxAutoTaskId() {
        String sql="select nvl(Max(t.autotask_id)+1,1) autotaskid from sys_autotask t";
        //调用JPA基础Manager操作sql语句
        Query query = this.entityManager.createNativeQuery(sql);
        BigDecimal bigId=(BigDecimal)query.getSingleResult();
        return bigId.intValue();
    }
}

这是对于oracle数据库的操作,其他数据库同样使用各自的sql语句是一样的。

具体操作方式可以查看官方文档ObjectDB(注:文档是英文版,英文不好的伙伴可以借助英文词典查看)

操作案例:BaseDao案例

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值