【SSM框架系列】Mybatis基本介绍

原始jdbc操作

	  	//1. 导入驱动jar包
        //2.注册驱动
        Class.forName("com.mysql.jdbc.Driver");
        //3.获取数据库连接对象
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db", "root", "root");
        //4.定义sql语句
        String sql = "update account set balance = 500 where id = 1";
        //5.获取执行sql的对象 Statement
        Statement stmt = conn.createStatement();
        //6.执行sql
        int count = stmt.executeUpdate(sql);
        //7.处理结果
        System.out.println(count);
        //8.释放资源
        stmt.close();
        conn.close();

原始jdbc操作的分析

查询数据库必须要有哪些条件:

  • 连接数据库的四个基本信息 driver,url,username,password
  • 必须要有执行的sql语句
  • 必须有结果集对应的实体对象(用于封装数据)

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

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

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

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

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

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

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

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

什么是Mybatis

  • mybatis 是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。

  • mybatis通过xml或注解的方式将要执行的各种 statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。

  • 最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc 进行了封装,屏蔽了jdbc api 底层访问细节,使我们不用与jdbc api 打交道,就可以完成对数据库的持久化操作。

Mybatis的基本入门

③编写Mybatis核心配置文件:mybatis-config.xml

④编写映射文件UserMapper.xml

⑤编码测试(先理解读懂,后期不用)

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

 	<dependencies>
        <!-- 连接数据库必须的依赖 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.32</version>
        </dependency>
        <!-- 方便查看日志,导入该依赖后,控制台可以打印更多日志 -->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <!-- 单元测试 -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
        <!-- lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.10</version>
        </dependency>
        <!-- mybatis依赖,mybatis开发只导入这个依赖即可 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.2</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>2.3.2</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>

编写Mybatis核心配置文件:mybatis-config.xml

    <?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:///test"/>
                    <property name="username" value="root"/>
                    <property name="password" value="135246"/>
                </dataSource>
            </environment>
        </environments>
        <!--加载映射文件-->
        <mappers>
            <mapper resource="cs/wy/dao/UserDao.xml"/>
        </mappers>
    </configuration>

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">
    <!-- namespace写接口的全类名 -->
    <mapper namespace="cs.wy.dao.UserDao">
        <!--
            id写接口中对应的方法名,这里相当于实现了接口中的方法
            resultType写返回值类型的全类名
         -->
        <select id="getUser" resultType="cs.wy.domain.User">
    --    这里写要执行的sql语句
          select * from user where id=1;
        </select>
    </mapper>

编写测试代码

    public class MybatisTest {
        @Test
        public void test01() throws IOException {
            // 指向mybatis的核心配置文件
            String resource = "mybatis-config.xml";
            // 加载核心配置文件到输入流
            InputStream inputStream = Resources.getResourceAsStream(resource);
            // 通过核心配置文件创建一个sqlSessionFactory,相当于一个连接工厂
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            // jdk7新特性 try with resource
            try (SqlSession session = sqlSessionFactory.openSession()) {
                // 形式类似于 app.getBean(UserDao.class)
                UserDao userDao = session.getMapper(UserDao.class);
                User user = userDao.getUser();
                System.out.println("user = " + user);
            }
        }
    }

MyBatis的增删改查操作

MyBatis的插入数据操作,

编写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">
    <!-- namespace写接口的全类名 -->
    <mapper namespace="cs.wy.dao.UserDao">
        <insert id="saveUser" parameterType="cs.wy.domain.User">
        	<!-- #{}中的值必须是实体类中的属性名称 -->
            insert into user values (null ,#{username},#{password})
        </insert>
    </mapper>

插入操作注意问题

  • 在映射文件中使用parameterType属性指定要插入的数据类型,该属性可以省略
  • Sql语句中使用#{实体属性名}方式引用实体中的属性值
  • sqlSession在操作前自动开启了事务。并且插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()
MyBatis的修改数据操作

编写UserMapper映射文件

    <update id="updateUser" >
    	<!-- #{}中的值必须是实体类中的属性名称 -->
        update user set username=#{username}, password=#{password} where id=#{id}
    </update>

插入操作注意问题

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

  • sqlSession在操作前自动开启了事务。并且更新操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()

MyBatis的删除数据操作

编写UserMapper映射文件

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

删除操作注意问题

  • 删除语句使用delete标签

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

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

MyBatis核心配置文件层级关系

在这里插入图片描述

MyBatis核心配置文件配置

settings 设置

  1. mapUnderscoreToCamelCase =true | false(default)
  2. mysql默认是大小写不敏感的,所以数据库表名和字段有_命名法的习惯
  3. Java默认是大小敏感的,所以类名、属性名一般会采用驼峰命名法
  4. 命名不一致时,会造成无法正确传值,这个时候可以将上述参数设置为true,会开启自动转换。

typeAliases 类型别名

为单个类起别名

       <typeAliases>
         	<typeAlias alias="user" type="cs.wy.domain.User"/>
       </typeAliases>
  1. 批量为某个包下的所有类起别名
       <typeAliases>
        	<-- 自动为该包下所有类起别名,并且大小写不敏感-->
         	<package name="domain.blog"/>
       </typeAliases>

常用内置数据类型自动别名

别名 映射的类型
_byte byte
_long long
_short short
_int int
_integer int
_double double
_float float
_boolean boolean
string String
byte Byte
long Long
short Short
int Integer
integer Integer
double Double
float Float
boolean Boolean
date Date
decimal BigDecimal
bigdecimal BigDecimal
object Object
map Map
hashmap HashMap
list List
arraylist ArrayList
collection Collection
iterator Iterator

4)environments标签

		<!--数据源环境 指定默认环境名称-->
        <environments default="development">
        	<!--指定当前环境名称-->
            <environment id="development">
            	<!--指定事务管理类型是JDBC-->
                <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="135246"/>
                </dataSource>
            </environment>
        </environments>

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

  • JDBC:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。

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

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

  • UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。

  • POOLED:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。

  • JNDI:这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的引用。

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"/>

MyBatis相应API

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 中加载资源文件。

SqlSession工厂对象:SqlSessionFactory

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

在这里插入图片描述

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()
发布了34 篇原创文章 · 获赞 14 · 访问量 1568

猜你喜欢

转载自blog.csdn.net/Wan_Yuan/article/details/104696219