ibatis中动态查询表返回用resultClass="java.util.HashMap" 的问题

[url]http://blog.youkuaiyun.com/dyllove98/article/details/4742588[/url]

<select id="getTableDataByPage" resultClass="java.util.HashMap" parameterClass="java.util.HashMap" remapResults="true">   
<![CDATA[
select * from (select rownum id,t.* from
$tableName$ t where rownum<= #endNum# ) b where b.id>= #startNum#
]]>
</select>
在 MyBatis 中,`<select>` 标签是用于定义 SQL 查询语句的核心标签,下面对包含你所提及参数配置的 `<select>` 标签代码进行解析: ### 标签参数含义 - **`id`**:`id` 属性是 `<select>` 标签的一个必需属性,用于唯一标识该查询语句。在上述例子中 `id="querycbxmlist"`,意味着这个查询的唯一标识符是 `querycbxmlist`,在 Java 代码中可以通过这个 `id` 来调用该查询。 - **`parameterClass`**:在较旧版本的 MyBatis 中使用 `parameterClass` 来指定传入 SQL 语句的参数类型。这里 `parameterClass="com.alibaba.fastjson.JSONObject"` 表示传入的参数类型是 `com.alibaba.fastjson.JSONObject`,即可以将一个 JSON 对象作为参数传递给这个 SQL 查询。不过在较新版本的 MyBatis 中,更多使用 `parameterType`。 - **`resultClass`**:同样在旧版本 MyBatis 中使用,用于指定 SQL 查询结果映射的 Java 类型。`resultClass="java.util.HashMap"` 表示查询结果将被映射为 `java.util.HashMap` 对象,即每一行记录会被封装成一个 `HashMap`,键是列名,值是列对应的值。在新版本中通常使用 `resultType`。 - **`remapResults`**:`remapResults` 一般用于控制是否重新映射结果集。`remapResults="true"` 表示会重新映射结果集,当多次执行一个查询时,MyBatis 会根据这个配置决定是否重新处理结果集映射。 ### 示例代码 以下是一个包含上述配置的 `<select>` 标签示例: ```xml <mapper namespace="com.example.mapper.QueryMapper"> <select id="querycbxmlist" parameterClass="com.alibaba.fastjson.JSONObject" resultClass="java.util.HashMap" remapResults="true"> SELECT * FROM your_table <where> <if test="condition1 != null"> column1 = #{condition1} </if> <if test="condition2 != null"> AND column2 = #{condition2} </if> </where> </select> </mapper> ``` ### Java 代码调用示例 ```java import com.alibaba.fastjson.JSONObject; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.InputStream; import java.util.HashMap; import java.util.List; public class Main { public static void main(String[] args) { // 加载 MyBatis 配置文件 String resource = "mybatis-config.xml"; InputStream inputStream = Main.class.getClassLoader().getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); // 创建 SQL 会话 try (SqlSession session = sqlSessionFactory.openSession()) { // 创建参数对象 JSONObject params = new JSONObject(); params.put("condition1", "value1"); params.put("condition2", "value2"); // 执行查询 List<HashMap<String, Object>> results = session.selectList("com.example.mapper.QueryMapper.querycbxmlist", params); // 处理结果 for (HashMap<String, Object> result : results) { System.out.println(result); } } } } ``` ### 代码用途 这段代码的主要用途是根据传入的 JSON 对象参数执行 SQL 查询,并将查询结果映射为 `HashMap` 对象列表。可以用于动态查询数据库,根据不同的条件筛选数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值