mybatis中如何接收动态参数的 select a.动态参数 from 动态表名
时间: 2024-10-14 12:08:41 浏览: 34
在MyBatis中,要接收动态参数并在`SELECT`语句中动态引用表名,你可以使用动态SQL标签,如`<foreach>`、`<if>`或自定义`<bind>`标签。以下是一个例子:
```xml
<select id="selectByDynamic" parameterType="map">
<choose>
<!-- 根据传入的条件选择不同的表名 -->
<when test="condition == 'table1'">
SELECT a.${dynamicParameter}
FROM table1 AS a
</when>
<when test="condition == 'table2'">
SELECT a.${dynamicParameter}
FROM table2 AS a
</when>
<!-- 添加更多可能的表名选项 -->
<!-- ... -->
<otherwise>
<!-- 如果不在上面的条件中,则可以选择默认表名 -->
SELECT a.${dynamicParameter}
FROM default_table AS a
</otherwise>
</choose>
</select>
```
在这个例子中,`parameterType`设置为`map`是因为我们需要一个键值对的容器来存储条件和参数。在调用这个方法时,可以这样传递参数:
```java
Map<String, Object> params = new HashMap<>();
params.put("condition", "table1"); // 表示从table1中选取
params.put("dynamicParameter", "yourDynamicColumn"); // 动态参数
List<Map<String, Object>> result = sqlSession.selectList("selectByDynamic", params);
```
记得根据你的需求调整`test`表达式和对应的表名。同时,要确保动态参数`dynamicParameter`是在每个表中都存在的列名。
阅读全文