前言:
目前主流框架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案例