MyBatis的理解以及配置和实现

MyBatis的理解以及配置和实现

  • 什么是MyBatis
  • MyBatis的作用
  • MyBatis的优缺点
    • 优点
    • 缺点
  • MyBatis的配置文件
    • properties元素
    • settings元素
    • typeAliases元素
    • environments元素
    • mappers元素
  • 如何实现MyBatis
    • 第一步 导入依赖
    • 第二步 创建MyBatis配置文件
    • 第三步 创建接口以及映射文件
    • 第四步 测试
  • 大家有什么意见可以提出来哦,蟹蟹大家

什么是MyBatis

MyBatis 是一款优秀的持久层框架,一个半 ORM(对象关系映射)框架,它支持定制化 SQL、存储过程以及高级映`射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生类型、接口和 Java 的 POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

MyBatis的作用

MyBatis作用是在持久层也就是访问数据库的操作,以前我们访问数据库是用JDBC来访问数据库,JDBC访问数据库需要写很多重复的代码,假如数据库访问很多还需要对数据库连接进行不停的打开连接和关闭连接,很消耗系统性能
MyBatis封装了JDBC底层访问数据库的代码,让我们程序猿只需要关心如何去写好SQL就好,不在需要去写JDBC底层的代码

MyBatis的优缺点

优点

  • MyBatis封装了JBDC底层访问数据库的细节,使我们程序猿不需要与JDBC API打交道,就可以访问数据库
  • MyBatis简单易学,程序猿直接编写SQL语句,适合于对SQL语句性能要求比较高的项目
  • SQL语句封装在配置文件中,便于统一管理与维护,降低了程序的耦合度
  • SQL代码从程序代码中彻底分离出来,可重用
  • 提供了动态SQL标签,支持编写动态SQL
  • 提供映射标签,支持对象与数据库的ORM字段关系映射

缺点

  • 过于依赖数据库SQL语句,导致数据库移植性差,更换数据库,如果SQL语句有差异,SQL语句工作量大
  • 由于xml里标签id必须唯一,导致DAO中方法不支持方法重载

MyBatis的配置文件

properties元素

properties元素描述的都是外部化,可替代的属性
一般用来配置连接数据源,我们可以使用property子节点来配置也可以使用资源路径引用

使用property子节点来配置

    <properties>
        <property name="driver" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql:///mybatis"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    properties>

使用资源路径引用

    <properties resource="jdbcConfig.properties"/>

jdbcConfig.properties里面的属性

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/test
username=root
password=123456

连接数据源的配置

	<dataSource type="POOLED">
        <property name="driver" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${username}"/>
        <property name="password" value="${password}"/>
    dataSource>

假如使用property子节点来配置和使用资源路径引用都用了,这个时候MyBatis会调用哪个勒?MyBatis会调用资源路径引用的属性值,因为资源路径引用的优先级高于property子节点的优先级

settings元素

settings是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为

    <settings>
        
        <setting name="cacheEnabled" value="true"/>
        
        
        <setting name="lazyLoadingEnabled" value="true"/>
        
        
        <setting name="aggressiveLazyLoading" value="false"/>
        
        
        <setting name="multipleResultSetsEnabled" value="true"/>
        
        
        <setting name="useColumnLabel" value="true"/>
        
        
        <setting name="useGeneratedKeys" value="true"/>
        
        
        <setting name="autoMappingBehavior" value="FULL"/>
        
        
        <setting name="defaultExecutorType" value="BATCH"/>
        
        
        <setting name="defaultStatementTimeout" value="25000"/>
    settings>

typeAliases元素

typeAliases元素的作用是给JavaBean取别名,方便我们在mappeer配置文件中使用

当我们没有给JavaBean取别名,mapper配置文件中获取JavaBean的时候,我们就需要获取JavaBean所在项目里面的全路径

    
    <select id="login" resultType="cn.friday.pojo.DevUser">
        SELECT * FROM dev_user WHERE devCode=#{devCode} AND devPassword=#{devPassword}
    select>

接下来我们就来给JavaBean取别名

    <typeAliases>
        <typeAlias type="cn.friday.pojo.DevUser" alias="devUser"/>
        <typeAlias type="cn.friday.pojo.AppInfo" alias="appInfo"/>
    typeAliases>

给每个JavaBean去取一个指定的别名,这样是有缺陷的,万一项目中有很多个POJO那么工作量就大了,不过还有一种方法给指定的包里面所有的JavaBean都取一个别名,MyBatis会自动扫描所指定的包下的JavaBean并且给一个默认的别名,默认的别名为JavaBean的名称,请看下面

    <typeAliases>
        <package name="cn.friday.pojo"/>
    typeAliases>

mapper里面的配置文件就可以正常使用JavaBean取的别名了,不需要再去获取JavaBean的全路径了

    
    <select id="login" resultType="DevUser">
        SELECT * FROM dev_user WHERE devCode=#{devCode} AND devPassword=#{devPassword}
    select>

environments元素

MyBatis可以配置多种环境,如开发环境、测试环境、生产环境等,我们可以灵活选择不同的配置,从而将SQL映射应用到不同的数据库环境上.这些不同的运行环境我们就可以用environments元素来配置实现

environments元素元素的配置

	
 	
    <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://127.0.0.1:3306/test"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            dataSource>
        environment>
        
        
         <environment id="test">
            
            <transactionManager type="JDBC"/>
            
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/test1"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            dataSource>
        environment>
    environments>

假如我们想从开发环境变成测试环境只需要修改environments元素里面的default属性即可

 <environments default="test">
 	
 environments>

mappers元素

mappers映射器,说简单点就是告诉MyBatis去哪里找到SQL语句映射文件,我们可以使用类资源路径或者是URL等
用类资源路径获取映射文件

    <mappers>
        <mapper resource="cn/friday/dao/developer/DevUserMapper.xml"/>
        <mapper resource="cn/friday/dao/developer/AppInfoMapper.xml"/>
    mappers>

用URL获取映射文件

    <mappers>
          <mapper url="file:///D:/mappers/DevUserMapper.xml"/>
          <mapper url="file:///D:/mappers/AppInfoMapper.xml"/>
    mappers>

如何实现MyBatis

先给大家看一下我的项目结构
MyBatis的理解以及配置和实现_第1张图片

第一步 导入依赖

我的是maven项目所以只需要在pox.xml配置文件中添加关于MyBatis的依赖即可


<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0modelVersion>

    <groupId>org.examplegroupId>
    <artifactId>MyBatisartifactId>
    <version>1.0-SNAPSHOTversion>

    <dependencies>
        <dependency>
            <groupId>junitgroupId>
            <artifactId>junitartifactId>
            <version>4.11version>
            <scope>testscope>
        dependency>

        <dependency>
        <groupId>mysqlgroupId>
        <artifactId>mysql-connector-javaartifactId>
        <version>6.0.6version>
    dependency>

        <dependency>
            <groupId>org.mybatisgroupId>
            <artifactId>mybatisartifactId>
            <version>3.4.4version>
        dependency>

    dependencies>

    <build>
    <resources>
        <resource>
            <directory>src/main/java/directory>
            <includes>
                <include>**/*.xmlinclude>
            includes>
        resource>
    resources>
    build>
project>

第二步 创建MyBatis配置文件

这些配置文件上面也用讲的过这里就不做过多的解释了



<configuration>
    <properties resource="jdbc-config.properties"/>

    <typeAliases>
        <package name="com.friday.pojo"/>
    typeAliases>

    <environments default="test">
        <environment id="test">
            <transactionManager type="JDBC">transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            dataSource>
        environment>
    environments>

    <mappers>
        <mapper resource="com/friday/dao/UserMapper.xml">mapper>
    mappers>
configuration>

jdbc-config.properties里面的属性

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTC
username=root
password=123456

第三步 创建接口以及映射文件

接口,普通的java接口

package com.friday.dao;

import com.friday.pojo.User;
import org.apache.ibatis.annotations.Param;

public interface UserMapper {
//@Param相对应给String userCode取了一个别名叫做userPassword,我们到写映射SQL语句的时候只有#{注解名称}即可,如#{userPassword}
    public User login(@Param("userCode") String userCode,@Param("userPassword") String pwd);
}

映射文件



<mapper namespace="com.friday.dao.UserMapper">
    <select id="login" resultType="User" parameterType="string">
        SELECT * FROM smbms_user WHERE userCode=#{userCode} AND userPassword=#{userPassword}
    select>
mapper>

mapper 文件里面的属性

  • namespace属性 指定相对应的接口
  • id属性 接口里面具体的方法名
  • resultType 返回值的类型
  • resultType 传进来的参数的类型

第四步 测试

package com.friday.test;

import com.friday.dao.UserMapper;
import com.friday.pojo.User;
import org.apache.ibatis.annotations.Param;
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 MyBatisTest {
   public static void main(String[] args) throws IOException {
       //读取mybatis配置文件
       String resource = "mybatis-config.xml";
       //获取mybatis配置文件的输入流
       InputStream is = Resources.getResourceAsStream(resource);
       //创建SqlSessionFactory对象
       SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
       //打开sqlSession对象
       SqlSession sqlSession =  factory.openSession();

       //获取对应的Mapper,让映射器通过命名空间和方法名称找到对应的SQL,发送给数据库执行后返回结果。
       User user = sqlSession.getMapper(UserMapper.class).login("zhanghua","userPassword");

       //看一下是否可以查到数据
       if (user != null) {
           System.out.println("登录成功");
       } else {
           System.out.println("登录失败");
       }

       //关闭sqlSession对象
       sqlSession.close();
   }
}

大家有什么意见可以提出来哦,蟹蟹大家

你可能感兴趣的:(MyBatis的理解以及配置和实现)