Java复习第十八天学习笔记(MVC,三层架构,分页),附有道云笔记链接
【有道云笔记】十八 4.4 MVC模式、三层架构、分页
https://note.youdao.com/s/PRQ62OUV
一、MVC
MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,
用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。
最简单的、最经典就是JSP(view) +Servlet(controller) + JavaBean(model)
视图和逻辑隔离开来
控制器是核心
M(Model) 模型 JavaBean
V(View) 视图 html jsp Thymeleaf volicity freemaker
C(Control) 控制器 Servlet,Controller,Action
- 当控制器收到来自用户的请求
- 控制器调用业务层完成JavaBean数据封装
- 完成业务后通过控制器跳转JSP页面的方式给用户反馈信息
- JSP个 用户做出响应。
什么是JavaBean
JavaBean:一种规范,表达实体和信息的规范,便于封装重用
- 所有属性为private
- 提供默认无参构造方法
- 提供getter和setter
- 实现serializable接口
二、三层架构
- Controller:负责控制,拿到View传递过来的数据,封装之后交给Service处理,Service处理完了之后,Controller拿到结果之后,将结果交给界面。
- Service:业务逻辑(分页,为了完成分页就要调用两次DAO层)
- DAO:纯粹的JDBC的增删改查操作
上一层可以调用下一层所有代码,并不是StudentServlet只能调用IStudentService代码,也可以调用ITeacherService代码
@WebServlet("/student") public class StudentServlet extends HttpServlet { private IStudentService studentService = new StudentServiceImpl(); private ITeacherService teacherService = new TeacherServiceImpl(); } public class StudentServiceImpl implements IStudentService { private IStudentDao studentDao = new StudentDaoImpl(); private ITeacherDao teacherDao = new TeacherDaoImpl(); } public class StudentDaoImpl implements IStudentDao { }
三、分页
limit 中offset代表偏移到哪个位置,rows代表往下数多少个
pageNo, pageSize 1,5 2,5 3,5
limit (pageNo-1)*pageSize ,pageSize
pageNo limit
1 0,5
2 5,5
3 10,5
分页常见的问题:
- 封装一个分页需要哪些信息
- 分页需要发送哪两条sql语句
public class PageInfo{ //当前页数据 private List<Student> list; //总的页数 Math.ceil(总数量/pageSize) private Integer totalPage; private Integer pageNo; private Integer pageSize; } //缺点是这个PageInfo只能封装Student,使用泛型就可以解决这个问题,这个T代表可以传递任何对象 public class PageInfo<T>{ private List<T> list; private Integer totalPage; private Integer pageNo; private Integer pageSize; } public static void main(String[] args) { int totalCount = 12; int pageSize = 5; int totalPage = (int)Math.ceil((double)totalCount / pageSize); System.out.println(totalPage);// 3 }
UserServlet.selectByPage com.mysql.cj.jdbc.ClientPreparedStatement: select id,name,password from users limit 0,5 com.mysql.cj.jdbc.ClientPreparedStatement: select count(*) from users PageInfo{list=[User{id=1, name='lisi', password='123'}, User{id=2, name='wangwu', password='123'}, User{id=3, name='dshfi', password='123'}, User{id=4, name='hweiohwi', password='12'}, User{id=5, name='12ih', password='23'}], totalPage=3, pageNo=1, pageSize=5} UserServlet.selectByPage com.mysql.cj.jdbc.ClientPreparedStatement: select id,name,password from users limit 5,5 com.mysql.cj.jdbc.ClientPreparedStatement: select count(*) from users PageInfo{list=[User{id=6, name='23hih', password='hio'}, User{id=7, name='hidosfhi', password='23'}, User{id=8, name='dhfih', password='34'}, User{id=9, name='ihdsfoih', password='23423'}, User{id=10, name='hdifh', password='232'}], totalPage=3, pageNo=2, pageSize=5} UserServlet.selectByPage com.mysql.cj.jdbc.ClientPreparedStatement: select id,name,password from users limit 10,5 com.mysql.cj.jdbc.ClientPreparedStatement: select count(*) from users PageInfo{list=[User{id=11, name='12hihi', password='iff'}, User{id=12, name='dhsfii', password='1212'}], totalPage=3, pageNo=3, pageSize=5}
原文地址:https://blog.csdn.net/m0_62220699/article/details/137652981
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!