【JPA】@query不適用于參數(shù)不確定的查詢,用EntityManager

最近做的項(xiàng)目,為了簡化Dao的代碼,使用了JPA來寫Dao,Dao的接口方法上使用@Query注釋,不需要再寫一個(gè)實(shí)現(xiàn)類(Impl)。
例子:

public interface IUserDao extends JpaRepository<User, String>,
  JpaSpecificationExecutor<User> {
  
  //根據(jù)ID查詢
  @Query(value = "select t from User t where t.id = ?1  order by t.code")
  List<User> getListById(String id);

  //根據(jù)ID更新NAME
  @Modifying
  @Query(value = "update User t set t.name= ?2 where t.id = ?1")
  void updateNameById(String id , String name);
}

在項(xiàng)目中,遇到一種情況,就是參數(shù)不確定的,例如網(wǎng)頁上的模糊查詢,“關(guān)鍵字”有可能是空的,這時(shí)候在Dao用@query就不方便了。

解決方法:用EntityManager

@PersistenceContext
private EntityManager em; //注入EntityManager 
public List<User> getUserList(String keyword){
  //構(gòu)建Query,注意用的是HQL語法
  String sql = " from User t where 1=1 "; 
  if(StringUtil.isNotNull(keyword)){//判斷keyword是否為空
    sql += " and t.name like ?1 "; //根據(jù)下標(biāo)
    //sql += "and t.name like :name "; //根據(jù)屬性
  }
  //Query query = new Query(sql);
  Query query = em.createQuery(sql);// 這里做個(gè)更正
  query.setParameter(1,keyword); //根據(jù)下標(biāo)
  //query.setParameter(name ,keyword); //根據(jù)屬性

  //查詢
  List<User > list = query.getResultList();
  return list;
}

做個(gè)更正:
2018-06-12 query應(yīng)該是用EntityManager創(chuàng)建的 Query query = em.createQuery(sql)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容