当前位置 博文首页 > 立志欲坚不欲锐,成功在久不在速度:【Mybatis系列】 如何使用My

    立志欲坚不欲锐,成功在久不在速度:【Mybatis系列】 如何使用My

    作者:[db:作者] 时间:2021-07-31 08:58

    前言:?在总结这边博客之前其实自己已经在使用mybatis了,但是对于mybatis只是停留在了一个简单的使用上面,那么我们为什么不使用JDBC?而要用Mybatis??下面就来介绍一下

    JDBC存在的问题:

    1. 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库连接池可解决此问题。
    2. Sql 语句在代码中硬编码,造成代码不易维护,实际应用 sql 变化的可能较大,sql 变动需要改变 java 代码。
    3. 使用 preparedStatement 向占位符号传参数存在硬编码,因为 sql 语句的 where 条件不一定,可能多也可能少,修改 sql 还要修改代码,系统不易维护。
    4. 对结果集解析存在硬编码(查询列名),sql 变化导致解析代码变化,系统不易维护,如果能将数据库记录封装成 pojo 对象解析比较方便

    什么是Mybatis:

    ? ? mybatis是一款持久层框架,避免了几乎所有的JDBC代码和手动设置参数的过程

    什么是持久化?

    ? ? 把数据(即内存中的对象)保存到可永久保存的存储设备中,

    为什么要进行持久化服务?

    ? ? 内存断电之后数据会丢失,但是有一些对象是无论如何都不会丢失的,内存相比硬盘来说价格过于昂贵

    下面我们用一个简单的例子来介绍mybatis的使用

    首先创建一个Maven项目:

    • 导入依赖:
    <dependency>
       <groupId>org.mybatis</groupId>
       <artifactId>mybatis</artifactId>
       <version>3.5.2</version>
    </dependency>
    <dependency>
       <groupId>mysql</groupId>
       <artifactId>mysql-connector-java</artifactId>
       <version>5.1.47</version>
    </dependency>
    • 编写Mybatis核心配置文件:
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
           PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
           "http://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/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8"/>
                   <property name="username" value="root"/>
                   <property name="password" value="123456"/>
               </dataSource>
           </environment>
       </environments>
       <mappers>
           <mapper resource="com/kuang/dao/userMapper.xml"/>
       </mappers>
    </configuration>

    environments表示多环境,一个配置文件可以有多个环境,比如测试,开发,生产,每一个environment都有自己的id

    default表示默认环境

    • 创建实体类:
    public class User {  
       private int id;  //id
       private String name;   //姓名
       private String pwd;   //密码
       
       //构造,有参,无参
       //set/get
       //toString()
    }
    • 编写Mapper接口:
    import com.kuang.pojo.User;
    import java.util.List;
    public interface UserMapper {
       List<User> selectUser();
    }
    • 编写Mapper.xml配置文件
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
           PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
           "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="com.kuang.dao.UserMapper">
     <select id="selectUser" resultType="com.kuang.pojo.User">
      select * from user
     </select>
    </mapper>
    • 最后加载主配置文件:
    public class MyTest {
       @Test
       public void selectUser() {
           SqlSession session = MybatisUtils.getSession();
           //方法一:
           //List<User> users = session.selectList("com.kuang.mapper.UserMapper.selectUser");
           //方法二:
           UserMapper mapper = session.getMapper(UserMapper.class);
           List<User> users = mapper.selectUser();
     
           for (User user: users){
               System.out.println(user);
          }
           session.close();
      }
    }

    ? ? ? ? sqlSessionFactoryBuilder? 创建? sqlSessionFactory

    ? ? ? ? sqlSessionFactory创建sqlSession

    ? ? ? ? ?在这里,SqlSessionFactoryBuilder 用于创建 SqlSessionFacoty,SqlSessionFacoty 一旦创建完成就不需要 SqlSessionFactoryBuilder 了,因为 SqlSession 是通过 SqlSessionFactory 生产,所以可以将 SqlSessionFactoryBuilder 当成一个工具类使用,最佳使用范围是方法范围即方法体内局部变量。

    ? ? ? ? SqlSessionFactory 是一个接口,接口中定义了 openSession 的不同重载方法,SqlSessionFactory 的最佳使用范围是整个应用运行期间,一旦创建后可以重复使用,通常以单例模式管理 SqlSessionFactory

    • 创建MybatisUtils
    import org.apache.ibatis.io.Resources;
    import org.apache.ibatis.session.SqlSession;
    import org.apache.ibatis.session.SqlSessionFactory;
    import org.apache.ibatis.session.SqlSessionFactoryBuilder;
    import java.io.IOException;
    import java.io.InputStream;
     
    public class MybatisUtils {
     
       private static SqlSessionFactory sqlSessionFactory;
     
       static {
           try {
               String resource = "mybatis-config.xml";
               InputStream inputStream = Resources.getResourceAsStream(resource);
               sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
          } catch (IOException e) {
               e.printStackTrace();
          }
      }
     

    ?

    cs