@RequestMapping("/list") //分页查询数据 public String list( Integer p, Integer pageSize, Model model) { p = null == p ? 1 : p; //默认显示第一页 pageSize = null == pageSize ? 10 : pageSize; //默认每页显示10条 Page<Student> page = PageHelper.startPage(p, pageSize); List<ApartmentAdmin> systemAdmins = apartmentAdminService.list(); SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm"); systemAdmins.forEach(systemAdmin -> { systemAdmin.setCreateTimeStr(sdf1.format(systemAdmin.getCreateTime())); }); model.addAttribute("admininfoList", systemAdmins); //绑定接受参数 model.addAttribute("cp", page.getPageNum()); //当前页 model.addAttribute("tp", page.getPages()); //总页数 model.addAttribute("total", page.getTotal()); //总条数 model.addAttribute("pageListURL", "admininfo/list"); //总条数 return "apartment/admininfoList"; }请详细解释每一行代码
时间: 2023-06-27 20:05:45 浏览: 180
这是一个使用Spring MVC框架和MyBatis插件的Java Web应用程序中的一个控制器方法,用于处理分页查询数据请求。
1. `@RequestMapping("/list")`:该注解表示映射了一个URL路径,即当客户端发起"/list"请求时,将由该方法来处理。
2. `public String list(Integer p, Integer pageSize, Model model)`:该方法是控制器方法,返回一个字符串类型的视图名称。
3. `p = null == p ? 1 : p;`:这行代码用于设置当前页码数,默认为1,即第一页。
4. `pageSize = null == pageSize ? 10 : pageSize;`:这行代码用于设置每页显示的记录数,默认为10条。
5. `Page<Student> page = PageHelper.startPage(p, pageSize);`:这行代码使用MyBatis插件PageHelper来进行分页处理,将查询结果分页并封装到Page对象中。
6. `List<ApartmentAdmin> systemAdmins = apartmentAdminService.list();`:这行代码调用业务逻辑层(apartmentAdminService)的list()方法,获取从数据库中查询出的数据列表。
7. `SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");`:这行代码创建一个日期格式化对象,用于将日期类型转换为指定格式的字符串类型。
8. `systemAdmins.forEach(systemAdmin -> { systemAdmin.setCreateTimeStr(sdf1.format(systemAdmin.getCreateTime())); });`:这行代码使用Lambda表达式遍历数据列表,并对每个对象的创建时间(createTime)属性进行格式化,将转换后的字符串保存到该对象的createTimeStr属性中。
9. `model.addAttribute("admininfoList", systemAdmins);`:这行代码将从数据库中查询出的数据列表添加到Model对象中,以便在视图中进行使用。
10. `model.addAttribute("cp", page.getPageNum());`:这行代码将当前页码数添加到Model对象中,以便在视图中进行使用。
11. `model.addAttribute("tp", page.getPages());`:这行代码将总页码数添加到Model对象中,以便在视图中进行使用。
12. `model.addAttribute("total", page.getTotal());`:这行代码将总记录数添加到Model对象中,以便在视图中进行使用。
13. `model.addAttribute("pageListURL", "admininfo/list");`:这行代码将页面的URL地址添加到Model对象中,以便在视图中进行使用。
14. `return "apartment/admininfoList";`:这行代码返回一个字符串类型的视图名称,通常是一个JSP页面的名称,用于展示分页查询结果。
阅读全文