我是靠谱客的博主 繁荣烤鸡,这篇文章主要介绍Mybatis注解使用script、foreach、if等标签执行select/insert操作场景使用方法,现在分享给大家,希望可以做个参考。

场景

在使用mybatis中@select@update等注解进行操作是,如何使用foreach条件。

使用方法

使用script标签定义sql,如下:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Select; import java.util.List; @Mapper public interface LizzMapper { @Select({"<script> select id,name " + " from t_lizz" + " where id in" + " <foreach collection="ids" index="index" item="item" open="(" separator="," close=")">" + " #{item}" + " </foreach>" + "</script>"}) List<Lizz> selectAllbyList(List<Integer> ids); @Insert({"<script> insert into t_lizz(id,name)" + " values" + " <foreach collection="datas" item="item" separator="," >" + " (#{item.id},#{item.name})" + " </foreach>" + "</script>"}) insert selectAllbyList(List<Lizz> datas); @Select({"<script> select id,name " + " from t_lizz" + " where id in" + " <foreach collection="ids.split(',')" index="index" item="item" open="(" separator="," close=")">" + " #{item}" + " </foreach>" + "<if test='state != null'>" + " and state= #{state} " + "</if> " + "</script>"}) List<AlertRule> selectAllByString(String ids,Integer state); @Select({"<script> select id,name " + " from t_lizz" + " where " + " <choose> "+ " <when test='state != null and state!=0 '>" + " and state= #{state} " + " </when> " + " <otherwise>" + " and state= 0 " + " </otherwise> " + " </choose> "+ "</script>"}) List<AlertRule> selectAllByString(String ids,Integer state); }

最后

以上就是繁荣烤鸡最近收集整理的关于Mybatis注解使用script、foreach、if等标签执行select/insert操作场景使用方法的全部内容,更多相关Mybatis注解使用script、foreach、if等标签执行select/insert操作场景使用方法内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(83)

评论列表共有 0 条评论

立即
投稿
返回
顶部