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