MyBatis

官网:https://mybatis.org/mybatis-3/zh/index.html
MyBatis应用在Dao层,封装了很多JDBC的操作。
DAO(Data Access Object):数据访问对象
DTO(Data Transfer Object):数据传输对象,就是JavaBeans数据模型
entity实体类:entity表示对数据库中所有表的映射,是根据数据库表字段设计出来的实体(要求表名与类名相同,字段名与成员变量名相同)
vo包:表示前端页面传过来的如表单等数据的字段,比如当前端填写了一个表单,当前端传过来的数据较多时,我们可以创建一个vo实体类,将前端传来的数据字段名作为成员变量名,这样我们就可以使用@RequestBody注解快速获取参数内容,而不需要使用Request对象来一个个获取,方便开发。
而dto包:表示的是 vo和entity的一个中间转换对象,是vo或entity对象中属性的一个子对象。当前端传来vo数据,我们提取vo中的数据到dto中,再将dto的数据处理后全部移动到entity中进行数据的保存。反之亦然。

Impl : DAO接口的真实实现类,完成具体的数据库操作

数据库事务(Database Transaction)

如果将N个数据库操作放到同一个事务中,那么这N个操作最终要么都生效,要么都不生效。(原子性)

START TRANSACTION;  //开启事务
执行语句
COMMIT; //提交事务(让事务生效)
ROLLBACK; //回滚事务(回滚到开启事务前的状态)

在Java中:
JDBC的写法:
connection.setAutoCommit(false); //开启事务(告诉程序不要自动提交事务,手动提交)
connection.commit();  //提交事务
connection.rollback(); //回滚  (可以用try、catch,回滚放在catch里)

事务的四大特性(ACID):原子性、一致性、隔离性、持久性。

导入依赖


  org.mybatis
  mybatis
  x.x.x

准备核心配置文件

mybatis-config.xml




  
     //开发环境
      
      
        
         //dev为开发环境的数据库、其他环境可以对应创建
        
        
      
    
  
  
     //映射文件(多个)
  
  
     //开启驼峰命名自动映射,即数据库列名 a_column 映射到Java属性名 aColumn
    //其他各种设置项参照:https://mybatis.org/mybatis-3/zh/configuration.html#settings
  

创建对应数据模型的映射文件

如skill模型:mappers/skill.xml




  

装载配置文件,创建Session

#import java.io.Reader
#import org.apache.ibatis.io.Resources
try (Reader reader = Resources.getResourceAsReader("mybatis-config.xml")) { //读取xml文件
  SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); //创建工厂构建器
  SqlSessionFactory factory = builder.build(reader); //创建工厂
  SqlSession session = factory.openSession(); //创建Session

  List skills = session.selectList(statement: "skill.list") //selectList表示查出来是一个列表
  
  session.close(); //关闭session
}

你可能感兴趣的:(MyBatis)