MyBatis 第一篇

    科技2025-04-29  14

    MyBatis 系列

    MyBatis系列 篇一一、Mybatis简介二、Mybatis的快速入门2.1 MyBatis开发步骤2.2 环境搭建2.3 编写测试代码2.4 知识小结 三、 MyBatis的映射文件概述四. MyBatis的增删改查操作4.1 MyBatis的插入数据操作4.2 MyBatis的修改数据操作4.3 MyBatis的删除数据操作4.4 知识小结 五. MyBatis核心配置文件概述5.1 MyBatis核心配置文件层级关系5.2 MyBatis常用配置解析5.3 知识小结 六.MyBatis相应API6.1 SqlSession工厂构建器SqlSessionFactoryBuilder6.2 SqlSession工厂对象SqlSessionFactory6.3 SqlSession会话对象

    MyBatis系列 篇一

    一、Mybatis简介

    MyBatis 是一款优秀的 ORM(Object Relational Mapping,对象关系映射)框架,它可以通过对象和数据库之间的映射,将程序中的对象自动存储到数据库中。它是 Apache 提供的一个开源项目,之前的名字叫做 iBatis,2010 年迁移到了 Google Code,并且将名字改为我们现在所熟知的 MyBatis,又于 2013 年 11 月迁移到了 Github。

    MyBatis 提供了普通 SQL 查询、事务、存储过程等功能,它的优缺点如下

    优点:

    相比于 JDBC 需要编写的代码更少使用灵活,支持动态 SQL提供映射标签,支持对象与数据库的字段关系映射

    缺点:

    SQL 语句依赖于数据库,数据库移植性差SQL 语句编写工作量大,尤其在表、字段比较多的情况下

    总体来说,MyBatis 是一个非常优秀和灵活的数据持久化框架,适用于需求多变的互联网项目,也是当前主流的 ORM 框架。

    二、Mybatis的快速入门

    2.1 MyBatis开发步骤

    MyBatis官网地址:https://mybatis.org/mybatis-3/zh/index.html

    MyBatis开发步骤:

    ①添加MyBatis的坐标

    ②创建user数据表

    ③编写User实体类

    ④编写映射文件UserMapper.xml

    ⑤编写核心文件SqlMapConfig.xml

    ⑥编写测试类

    2.2 环境搭建

    1)通过骨架创建一个Maven项目,补全项目并导入MyBatis的坐标和其他相关坐标

    打开idea,点击 Create New Project 选择Maven,选中使用骨架创建.选择下图标注的骨架,点击Next 定义项目的全类名 + 项目名称. 如果是第一次使用骨架,建议如下图操作: 1.点击 +号,键盘录入 archetypeCatalog ,value 是 internal,这样使用骨架创建项目的时候,不会下载更多相关的插件.加快项目构建速度. 2. 检查自己的Maven环境.点击ok,点击Next.

    等待Maven构建项目,看见BUILD SUCCESS 项目构建完成.

    展开项目,发现项目构建的并步完全,需要手动补全.

    选中main,鼠标右键,点击 New ,选择Directory.如果是第一次创建.键盘录入 java.点击回车.

    同样方式创建resources.如果创建出来的文件夹是黑黑的普通文件夹.选中java,鼠标右键,点击 Mark Directort as Sources Root,如下图所示:

    resources文件夹同样标识为Resources Root,如下图.

    点击src,鼠标右键,点击New Directory. 键盘录入 test\java,同上,将此文件夹标识为Test Sources Root .

    至此,项目构架基本搭建完成.接下来通过 pom.xml引入依赖.引入依赖如下:

    <!--mybatis坐标--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.5</version> </dependency> <!--mysql驱动坐标--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.6</version> <scope>runtime</scope> </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.12</version> </dependency> 创建user数据表

    编写User实体 public class User { private int id; private String username; private String password; //省略get个set方法 }

    4)编写UserMapper映射文件,在resources 目录下创建一个包,专门用来放置配置文件.需要注意:在resources目录下创建包的时候,不能再用点,而应该用/

    <?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="cn.yespatal.domain.User"> select * from User </select> </mapper> 编写MyBatis核心文件. datasource这里先先直接加入.通过文件引入后面章节会加上 <!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:///test"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments> <mappers> <mapper resource="cn/yespatal/mapper/UserMapper.xml"/> </mappers> </configuration>

    整体项目结构如下

    2.3 编写测试代码

    //加载核心配置文件 InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml"); //获得sqlSession工厂对象 SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream); //获得sqlSession对象 SqlSession sqlSession = sqlSessionFactory.openSession(); //执行sql语句 List<User> userList = sqlSession.selectList("userMapper.findAll"); //打印结果 System.out.println(userList); //释放资源 sqlSession.close();

    2.4 知识小结

    MyBatis开发步骤:

    ①添加MyBatis的坐标

    ②创建user数据表

    ③编写User实体类

    ④编写映射文件UserMapper.xml

    ⑤编写核心文件SqlMapConfig.xml

    ⑥编写测试类

    三、 MyBatis的映射文件概述

    四. MyBatis的增删改查操作

    4.1 MyBatis的插入数据操作

    1)编写UserMapper映射文件

    <mapper namespace="userMapper"> <insert id="add" parameterType="com.yespatal.domain.User"> insert into user values(#{id},#{username},#{password}) </insert> </mapper>

    2)编写插入实体User的代码

    InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream); SqlSession sqlSession = sqlSessionFactory.openSession(); int insert = sqlSession.insert("userMapper.add", user); System.out.println(insert); //提交事务 sqlSession.commit(); sqlSession.close();

    3)插入操作注意问题

    • 插入语句使用insert标签

    • 在映射文件中使用parameterType属性指定要插入的数据类型

    •Sql语句中使用#{实体属性名}方式引用实体中的属性值

    •插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);

    •插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()

    4.2 MyBatis的修改数据操作

    1)编写UserMapper映射文件

    <mapper namespace="userMapper"> <update id="update" parameterType="com.yespatal.domain.User"> update user set username=#{username},password=#{password} where id=#{id} </update> </mapper>

    2)编写修改实体User的代码

    InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream); SqlSession sqlSession = sqlSessionFactory.openSession(); int update = sqlSession.update("userMapper.update", user); System.out.println(update); sqlSession.commit(); sqlSession.close();

    3)修改操作注意问题

    • 修改语句使用update标签

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

    4.3 MyBatis的删除数据操作

    1)编写UserMapper映射文件

    <mapper namespace="userMapper"> <delete id="delete" parameterType="java.lang.Integer"> delete from user where id=#{id} </delete> </mapper>

    2)编写删除数据的代码

    InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream); SqlSession sqlSession = sqlSessionFactory.openSession(); int delete = sqlSession.delete("userMapper.delete",3); System.out.println(delete); sqlSession.commit(); sqlSession.close();

    3)删除操作注意问题

    • 删除语句使用delete标签

    •Sql语句中使用#{任意字符串}方式引用传递的单个参数

    •删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);

    4.4 知识小结

    增删改查映射配置与API: 查询数据: List<User> userList = sqlSession.selectList("userMapper.findAll"); <select id="findAll" resultType="com.yespatal.domain.User"> select * from User </select> 添加数据: sqlSession.insert("userMapper.add", user); <insert id="add" parameterType="com.yespatal.domain.User"> insert into user values(#{id},#{username},#{password}) </insert> 修改数据: sqlSession.update("userMapper.update", user); <update id="update" parameterType="com.yespatal.domain.User"> update user set username=#{username},password=#{password} where id=#{id} </update> 删除数据:sqlSession.delete("userMapper.delete",3); <delete id="delete" parameterType="java.lang.Integer"> delete from user where id=#{id} </delete>

    五. 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标签

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

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

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

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

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

    3)Properties标签

    实际开发中,习惯将数据源的配置信息单独抽取成一个properties文件,该标签可以加载额外配置的properties文件

    4)typeAliases标签

    类型别名是为Java 类型设置一个短的名字。原来的类型名称配置如下

    配置typeAliases,为com.itheima.domain.User定义别名为user

    上面我们是自定义的别名,mybatis框架已经为我们设置好的一些常用的类型的别名

    5.3 知识小结

    核心配置文件常用配置:

    properties标签:该标签可以加载外部的properties文件

    <properties resource="jdbc.properties"></properties>

    typeAliases标签:设置类型别名

    <typeAlias type="com.itheima.domain.User" alias="user"></typeAlias>

    mappers标签:加载映射配置

    <mapper resource="com/itheima/mapper/UserMapping.xml"></mapper>

    environments标签:数据源环境配置标签

    六.MyBatis相应API

    6.1 SqlSession工厂构建器SqlSessionFactoryBuilder

    常用API:SqlSessionFactory build(InputStream inputStream)

    通过加载mybatis的核心文件的输入流的形式构建一个SqlSessionFactory对象

    String resource = "org/mybatis/builder/mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); SqlSessionFactory factory = builder.build(inputStream);

    其中, Resources 工具类,这个类在 org.apache.ibatis.io 包中。Resources 类帮助你从类路径下、文件系统或一个 web URL 中加载资源文件。

    6.2 SqlSession工厂对象SqlSessionFactory

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

    6.3 SqlSession会话对象

    SqlSession 实例在 MyBatis 中是非常强大的一个类。在这里你会看到所有执行语句、提交或回滚事务和获取映射器实例的方法。

    执行语句的方法主要有:

    <T> T selectOne(String statement, Object parameter) <E> List<E> selectList(String statement, Object parameter) int insert(String statement, Object parameter) int update(String statement, Object parameter) int delete(String statement, Object parameter)

    操作事务的方法主要有:

    void commit() void rollback()
    Processed: 0.012, SQL: 8