jpa @Subselect 联表 子查询 动态添加参数

jpa 非原生sql,用传统的子查询写法,启动会报错,需要我们定义一个子查询对象。关联查询时关联定义的子查询的对象


@Entity
@Getter
@Setter
@Table(name = "数据库表名")
@Subselect(" select 字段 from 表 where  1=1 and (objectTypeIdStrFilter.objectTypeIdStr = '' or objectTypeIdStrFilter.objectTypeIdStr is null or 数据库字段=objectTypeIdStrFilter.objectTypeIdStr ) " ) // 动态参数
@Synchronize( {"数据库表名"} ) //tables impacted
@EntityListeners(AuditingEntityListener.class) // 固定写法
@FilterDef(
  name = "objectTypeIdStrFilter", // 自定义过滤器  名字随意
  parameters = @ParamDef(name = "objectTypeIdStr", type = "string") // 需要传入参数的字段
)
public class B implements Serializable {

}

定义sql

String sql = "select *from A left join B "

  Session session = entityManager.unwrap(Session.class); // 必要写法
// 必要写法
    session.enableFilter("objectTypeIdStrFilter").setParameter("objectTypeIdStr", 入参).validate();  // objectTypeIdStrFilter 自定义的过滤器 objectTypeIdStr 参数  
    Query query = entityManager.createQuery(sql);
    query.unwrap(QueryImpl.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值