MyBatis框架概述
1.1 框架
- 对通用代码的封装,提前写好了一堆接口和类,我们可以在做项目的时候直接引入这些接口和类(引入框架),基于这些现有的接口和类进行开发,可以大大提高开发效率。
1.2 MVC三层架构
- 讲解MyBatis框架前,我们有必要明白Web项目中的软件分层,以及MyBatis框架在其中扮演什么角色?
- M:model(模型层),负责一个软件具体要实现的功能、操作数据库以及数据库对应的实体类创建。
- 数据库对应实体类,常见的包名命名方式如pojo、domain、bean。
- 服务层,常见的包名命名方式如service,作用是实现具体的功能,该层通常包括service接口和具体实现类impl。
- 数据层,常见的包名命名方式如dao、mapper,作用是实现对数据库的操作以及查询数据。
- V:view(视图层),负责收集前端数据以及展示后台提供的数据。
- C:controller(控制层),负责前后端数据交互,能够处理前端请求,并且作出响应。
- 控制层,常见的包名命名方式如controller,即各个控制器,负责对应的前端数据交互功能。
1.3 JDBC对数据库进行操作的不足
String sql = "select id,idCard,username,password,birth,gender,email,city,street,zipcode,phone,grade from t_user";
PreparedStatement ps = conn.prepareStatement(sql);
ResultSet rs = ps.executeQuery();
List<User> userList = new ArrayList<>();
while(rs.next()){
String id = rs.getString("id");
String idCard = rs.getString("idCard");
String username = rs.getString("username");
String password = rs.getString("password");
String birth = rs.getString("birth");
String gender = rs.getString("gender");
String email = rs.getString("email");
String city = rs.getString("city");
String street = rs.getString("street");
String zipcode = rs.getString("zipcode");
String phone = rs.getString("phone");
String grade = rs.getString("grade");
User user = new User();
user.setId(id);
user.setIdCard(idCard);
user.setUsername(username);
user.setPassword(password);
user.setBirth(birth);
user.setGender(gender);
user.setEmail(email);
user.setCity(city);
user.setStreet(street);
user.setZipcode(zipcode);
user.setPhone(phone);
user.setGrade(grade);
userList.add(user);
}
1.4 MyBatis框架
- MyBatis本质上就是对JDBC的封装,通过MyBatis完成CRUD。
- MyBatis在三层架构中负责持久层的,属于持久层框架。
- 其通过ORM对象关系映射使数据库和实体类进行对应,是一个半自动化的框架。
- 特点:
- 支持定制化 SQL、存储过程、基本映射以及高级映射
- 避免了几乎所有的 JDBC 代码中手动设置参数以及获取结果集
- 支持XML开发,也支持注解式开发。【为了保证sql语句的灵活,所以mybatis大部分是采用XML方式开发。】
码中手动设置参数以及获取结果集 - 支持XML开发,也支持注解式开发。【为了保证sql语句的灵活,所以mybatis大部分是采用XML方式开发。】