加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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应该是微不足道的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读