jpa @Query注解动态传入数据库表名、字段名查询和排序

1、需求

有一些情况下前端从后台获取数据时是需要从前端传字段名的。如:

    @Query(nativeQuery = true, value = "select * from _table where find_in_set(?1, ?2)")
    List<> query(String string1, String field);

但这种情况下并不能进行有效查询,原因是 field字段名在数据库执行查询时例如应该是 type 。实际上却是 ‘type’ 字符串

2、一种解决办法

使用case语句,可以在执行查询前先判断传来的field内容,然后动态生成sql语句。如:

    @Query(nativeQuery = true, value = "select * from _table where find_in_set(?1, case ?2 when 'type' then type when 'name' then name end)")
    List<> query(String string1, String field);

利用此方法也可以根据传入的字段名进行order by排序。

(耶!,撒花!!)

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值