Mybatis (1)—开发步骤、映射文件和核心配置文件的概述

22 篇文章 0 订阅
本文详细介绍了MyBatis持久层框架,包括原始JDBC操作的问题、MyBatis的优势以及解决这些问题的方法。逐步解析了MyBatis的快速入门步骤,包括引入依赖、创建数据表、编写实体类、映射文件和核心配置文件。此外,还深入讨论了MyBatis的增删改查操作,提供了具体的XML映射文件示例和操作注意事项。最后,概述了MyBatis核心配置文件的层级关系和常用配置解析。
摘要由CSDN通过智能技术生成

目录

一、Mybatis简介

1.1 原始jdbc操作

1.2 原始jdbc操作的分析

1.3 什么是Mybatis

二、Mybatis的快速入门

2.1 MyBatis开发步骤

2.2 代码实现

三、Mybatis的映射文件概述

四、MyBatis的增删改查操作

4.1 MyBatis的插入数据操作

4.1.1 插入操作注意问题

4.2 MyBatis的修改数据操作

4.2.1 修改操作注意问题

4.3 MyBatis的删除数据操作

4.3.1删除操作注意问题

4.4 知识小结

五、Mybatis核心配置为文件概述

5.1 MyBatis核心配置文件层级关系

5.2 MyBatis常用配置解析

5.3 知识小结

六、Mybatis相应API

6.1 SqlSession工厂构建器SqlSessionFactoryBuilder

6.2 SqlSession工厂对象SqlSessionFactory

6.3 SqlSession会话对象


一、Mybatis简介

1.1 原始jdbc操作

  • 查询数据

  •  插入数据

1.2 原始jdbc操作的分析

原始jdbc开发存在的问题如下:

① 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能

② sql 语句在代码中硬编码,造成代码不易维护,实际应用 sql 变化的可能较大,sql 变动需要改变java代码。

③ 查询操作时,需要手动将结果集中的数据手动封装到实体中。插入操作时,需要手动将实体的数据设置到sql语句的占位 符位置

应对上述问题给出的解决方案:

① 使用数据库连接池初始化连接资源

② 将sql语句抽取到xml配置文件中

③ 使用反射、内省等底层技术,自动将实体与表进行属性与字段的自动映射

1.3 什么是Mybatis

  • mybatis是一个优秀的基于Java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。
  • mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过Java对象和statement中sql的动态参数进行映射生成最终执行的sql语句
  • 最后mybatis框架执行sql并将结果映射为Java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了jdbc api底层访问细节,使我们不用与jdbc api打交道,就可以完成对数据库的持久化操作

二、Mybatis的快速入门

2.1 MyBatis开发步骤

① 导入MyBatis的坐标

② 创建user数据表

③ 编写User实体类

④ 编写映射文件UserMapper.xml

⑤ 编写核心文件SqlMapConfig.xml

⑥ 编写测试类

2.2 代码实现

1. 导入MyBatis的坐标和其他相关坐标

   <dependencies>
        <!--mysql驱动坐标-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.46</version>
        </dependency>
        <!--mybatis坐标-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.5</version>
        </dependency>
        <!--单元测试坐标-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
        <!--日志控制坐标-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
    </dependencies>

2. 创建user数据表

 3. 编写User实体

public class User {

    private int id;
    private String username;
    private String password;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}

 4. 编写UserMapper映射文件

<?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="userMapper">
    <select id="findAll" resultType="com.learn.domain.User">
        select * from user
    </select>
</mapper>

5. 编写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"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/test"/>
                <property name="username" value="root"/>
                <property name="password" value="XXXXX"/>
            </dataSource>
        </environment>
    </environments>

    <!--加载映射文件-->
    <mappers>
        <mapper resource="com/learn/mapper/UserMapper.xml"></mapper>
    </mappers>

</configuration>

6. 编写测试代码

public class MybatisTest {

    @Test
    public void test1() throws IOException {
        //获得核心配置文件
        InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapperConfig.xml");
        //获得session工厂对象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
        //获得session会话对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //执行操作 参数:namespace+id
        List<User> userList = sqlSession.selectList("userMapper.findAll");
        //打印数据
        System.out.println(userList);
        //释放资源
        sqlSession.close();
    }
}

三、Mybatis的映射文件概述

四、MyBatis的增删改查操作

4.1 MyBatis的插入数据操作

编写UserMapper映射文件

<mapper namespace="userMapper">

    <!--插入操作-->
    <insert id="save" parameterType="com.learn.domain.User">
        insert into user values(#{id},#{username},#{password})
    </insert>

</mapper>

​

编写插入实体User的代码

    @Test
    public void test2() throws IOException {

        //模拟user对象
        User user = new User();
        user.setUsername("tom");
        user.setPassword("233");

        //获得核心配置文件
        InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapperConfig.xml");
        //获得session工厂对象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
        //获得session会话对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //执行操作 参数:namespace+id
        sqlSession.insert("userMapper.save", user);
        //mybatis执行更新操作,需要提交事务
        sqlSession.commit();

        //释放资源
        sqlSession.close();
    }

4.1.1 插入操作注意问题

  • 插入语句使用insert标签
  • 在映射文件中使用parameterType属性指定要插入的数据类型
  • Sql语句中使用 #{实体属性名} 方式引用实体中的属性值
  • 插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);
  • 插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务, 即sqlSession.commit()

4.2 MyBatis的修改数据操作

编写UserMapper映射文件

<mapper namespace="userMapper">

    <!--修改操作-->
    <update id="update" parameterType="com.learn.domain.User">
        update user set username=#{username},password=#{password} where id=#{id}
    </update>

</mapper>

编写修改实体User的代码

    //修改操作
    @Test
    public void test3() throws IOException {

        //模拟user对象
        User user = new User();
        user.setId(7);
        user.setUsername("lucy");
        user.setPassword("000");

        //获得核心配置文件
        InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapperConfig.xml");
        //获得session工厂对象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
        //获得session会话对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //执行操作 参数:namespace+id
        sqlSession.update("userMapper.update",user);
        //mybatis执行更新操作,需要提交事务
        sqlSession.commit();

        //释放资源
        sqlSession.close();
    }

4.2.1 修改操作注意问题

  • 修改语句使用update标签
  • 修改操作使用的API是sqlSession.update(“命名空间.id”,实体对象);

4.3 MyBatis的删除数据操作

编写UserMapper映射文件

<mapper namespace="userMapper">

    <!--删除操作-->
    <delete id="delete" parameterType="java.lang.Integer">
        delete from user where id=#{id}
    </delete>

</mapper>

编写删除数据的代码

    //删除操作
    @Test
    public void test4() throws IOException {

        //获得核心配置文件
        InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapperConfig.xml");
        //获得session工厂对象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
        //获得session回话对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //执行操作  参数:namespace+id
        sqlSession.delete("userMapper.delete",7);

        //mybatis执行更新操作  提交事务
        sqlSession.commit();

        //释放资源
        sqlSession.close();
    }

4.3.1删除操作注意问题

  • 删除语句使用delete标签
  • Sql语句中使用#{任意字符串}方式引用传递的单个参数
  • 删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);

4.4 知识小结

五、Mybatis核心配置为文件概述

5.1 MyBatis核心配置文件层级关系

5.2 MyBatis常用配置解析

1. environments标签

其中,事务管理器(transactionManager)类型有两种:

  • JDBC:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
  • MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置 为 false 来阻止它默认的关闭行为。

其中,数据源(dataSource)类型有三种:

  • UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
  • POOLED:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。
  • JNDI:这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置 一个 JNDI 上下文的引用。

2. mapper标签

该标签的作用是加载映射的,加载方式有如下几种:

  • 使用相对于类路径的资源引用,例如:                                                       

        <mapper resource="org/mybatis/builder/AuthorMapper.xml"/>

  • 使用完全限定资源定位符(URL),例如:

        <mapper url="file:///var/mappers/AuthorMapper.xml"/>

  • 使用映射器接口实现类的完全限定类名,例如:

        <mapper class="org.mybatis.builder.AuthorMapper"/>

  • 将包内的映射器接口实现全部注册为映射器,例如:

        <package name="org.mybatis.builder"/>

3. Properties标签

4. typeAliases标签

5.3 知识小结

六、Mybatis相应API

6.1 SqlSession工厂构建器SqlSessionFactoryBuilder

6.2 SqlSession工厂对象SqlSessionFactory

SqlSessionFactory 有多个个方法创建 SqlSession 实例。常用的有如下两个:

6.3 SqlSession会话对象

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值