mapper的xml文件能够按以下方式来写:java
<!-- 用来记录分页查询时的全部数据量,避免出现分页查询时须要查询两次 --> <resultMap type="java.lang.Integer" id="count"> <result column="total"/> </resultMap> <!-- 多条件查询 /分页查询--> <select id="selectPage" resultMap="自定义的resultMap,count"> SELECT SQL_CALC_FOUND_ROWS * FROM 表名及条件 WHERE ID in (SELECT ID from (SELECT ID FROM A LIMIT ${(pageNo-1)*pageSize},#{pageSize}) AS t) order by ID; <!-- 查询数据量 --> SELECT FOUND_ROWS(*) AS total; </select>
mapper接口:web
List<Object> selectPage(@Param("pageNo") Integer pageNo, @Param("pageSize") Integer pageSize);
service层:sql
Mapper接口实例.selectPage(Integer pageNo,Integer pageSize);
controller层:app
List<Object> list = Service实例.selectPage(pageNo,pageSize); List<实体类名> wcenters = (List<实体类名>) list.get(0); //数据集合 Integer total = ((List<Integer>) list.get(1)).get(0);//总量
注意:在使用时须要在配置文件中,设置容许sql进行多语句执行:allowMultiQueries=true,在sql的url上加上这个配置就能够了。svg