java – QueryDsl查询参数?
发布时间:2020-12-15 02:11:09 所属栏目:Java 来源:网络整理
导读:使用jpa,我们有NamedQuery女巫让我们以这种方式传递参数: public T2 T2 getSingleResult(String namedQuery,MapString,String parameters,ClassT2 clazz) { TypedQueryT2 typedQuery = entityManager.createNamedQuery(namedQuery,clazz); for (EntryString
使用jpa,我们有NamedQuery女巫让我们以这种方式传递参数:
public <T2> T2 getSingleResult(String namedQuery,Map<String,String> parameters,Class<T2> clazz) { TypedQuery<T2> typedQuery = entityManager.createNamedQuery(namedQuery,clazz); for (Entry<String,String> parameter : parameters.entrySet()) { typedQuery.setParameter(parameter.getKey(),parameter.getValue()); } return typedQuery.getSingleResult(); } 所以我想知道,有没有类似的方法稍后使用QueryDsl传递参数? 解决方法
我在PathBuilder中使用以下方法:
PathBuilder pathBuilder = new PathBuilder(Object.class,"my_table"); SQLQuery query = new SQLQuery(connection,OracleTemplates.DEFAULT); query.from(pathBuilder.getRoot()) .where(pathBuilder.get("my_column").eq(new Param(String.class,"param1"))) .set(new Param(String.class,"param1"),"67") .list(pathBuilder.get("my_column")); 将代码调整为静态生成的QueryDSL bean应该是微不足道的. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |