mybaits通用查询mapper,传入参数查询字段和表名,返回list<map>
时间: 2024-02-12 15:07:54 浏览: 264
可以通过使用 MyBatis 的动态 SQL 来动态生成 SQL 语句,从而实现传入参数查询字段和表名,返回 List<Map> 的功能。具体步骤如下:
1. 在 mapper.xml 文件中编写动态 SQL。例如,以下代码可以根据传入的参数(表名和字段名)动态生成 SQL 语句:
```xml
<select id="selectFieldsFromTable" resultType="map">
SELECT
<foreach item="column" index="index" collection="fields" separator=",">
${column}
</foreach>
FROM ${table}
</select>
```
其中,`fields` 是一个 List<String> 类型的参数,包含要查询的字段名;`table` 是一个 String 类型的参数,表示要查询的表名。`${column}` 和 `${table}` 是 MyBatis 的动态 SQL 占位符,可以在运行时被实际的参数值替换。
2. 在对应的 Java 接口中定义方法,用于调用 mapper.xml 中的 SQL 语句。例如:
```java
public interface MyMapper {
List<Map<String, Object>> selectFieldsFromTable(@Param("table") String table, @Param("fields") List<String> fields);
}
```
其中,`@Param` 注解用于指定传入参数的名称,方便在 mapper.xml 中使用。
3. 在调用 mapper 方法时,传入相应的参数。例如:
```java
List<Map<String, Object>> result = myMapper.selectFieldsFromTable("user", Arrays.asList("id", "name", "age"));
```
这样就可以根据传入的参数查询指定表中的指定字段,并返回一个 List<Map>,每个 Map 包含一条记录的字段名和对应的值。
阅读全文