MyBatis

作者: Coder_JdHo | 来源:发表于2022-11-09 18:00 被阅读0次

    官网:https://mybatis.org/mybatis-3/zh/index.html
    MyBatis应用在Dao层,封装了很多JDBC的操作。
    Dao:数据访问对象

    数据库事务(Database Transaction)

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

    START TRANSACTION;  //开启事务
    执行语句
    COMMIT; //提交事务(让事务生效)
    ROLLBACK; //回滚事务(回滚到开启事务前的状态)
    
    在Java中:
    JDBC的写法:
    connection.setAutoCommit(false); //开启事务(告诉程序不要自动提交事务,手动提交)
    connection.commit();  //提交事务
    connection.rollback(); //回滚  (可以用try、catch,回滚放在catch里)
    

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

    导入依赖

    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>x.x.x</version>
    </dependency>
    

    准备核心配置文件

    mybatis-config.xml

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
      PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
      "https://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
      <environments default="development">
        <environment id="development"> //开发环境
          <transactionManager type="JDBC"/>
          <dataSource type="POOLED">
            <property name="driver" value="com.mysql.jdbc.Driver"/>
            <property name="url" value="jdbc:mysql://localhost:3306/dev"/> //dev为开发环境的数据库、其他环境可以对应创建
            <property name="username" value="root"/>
            <property name="password" value="123"/>
          </dataSource>
        </environment>
      </environments>
      <mappers>
        <mapper resource="mappers/skill.xml"/> //映射文件(多个)
      </mappers>
      <settings>
        <setting name="mapUnderscoreToCamelCase" value="true"> //开启驼峰命名自动映射,即数据库列名 a_column 映射到Java属性名 aColumn
        //其他各种设置项参照:https://mybatis.org/mybatis-3/zh/configuration.html#settings
      </settings>
    </configuration>
    

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

    如skill模型:mappers/skill.xml

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
      PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
      "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="skill">
      <select id="list" resultType="com.mj.bean.Skill"> //通过id找到这个select里对应的sql语句;resultType为查出数据的类型
        SELECT * FROM skill
      </select>
    </mapper>
    

    装载配置文件,创建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<Skill> skills = session.selectList(statement: "skill.list") //selectList表示查出来是一个列表
      
      session.close(); //关闭session
    }
    

    相关文章

      网友评论

          本文标题:MyBatis

          本文链接:https://www.haomeiwen.com/subject/owayortx.html