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案例

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章