Mybatis 简介01

Mybatis 简介

SSM Spring SpringMVC Mybatis

1.mybatis概述

1.1 mybatis简介
  • MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。
  • MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。
  • MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录.
1.2 mybatis历史

原是apache的一个开源项目iBatis, 2010年6月这个项目由apache software foundation 迁移到了google code,随着开发团队转投Google Code旗下,ibatis3.x正式更名为Mybatis ,代码于2013年11月迁移到Github(下载地址见后)。

iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO)

1.3 为什么要使用mybatis

MyBatis是一个半自动化的持久化层框架。

jdbc编程—当我们使用jdbc持久化的时候,sql语句被硬编码到java代码中。这样耦合度太高。代码不易于维护。在实际项目开发中会经常添加sql或者修改sql,这样我们就只能到java代码中去修改。

对开发人员而言,核心sql还是需要自己优化

sql和java编码分开,功能边界清晰,一个专注业务、一个专注数据。

可以使用简单的XML或注解用于配置方法的sql语句,将接口和Java的POJO映射成数据库中的记录。成为业务代码+底层数据库的媒介

2.mybatis 的 hello示例程序

  1. 数据库搭建
    drop database mybatis;
    CREATE database mybatis DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
    use mybatis;
    ## 创建单表
    create table t_user(
    `id` int primary key auto_increment,
    `last_name`	varchar(50),
    `sex` int
    );
    insert into t_user(`last_name`,`sex`) values('laox',1);
    select * from t_user;
    
    
    2.导包

    junit_4.12.jar

    mybatis-3.5.1.jar

    mysql-connector-java-5.1.7-bin.jar

    org.hamcrest.core_1.3.0.jar

    3.编写User对象

    public class User {
        private Integer id;
        private String lastName;
        private Integer sex;
        ...
        }
    
    4.各个包位置

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9DLumjCR-1608194328338)(C:\Users\psd\AppData\Roaming\Typora\typora-user-images\image-20201130201538107.png)]

    1. 配置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 : 环境就是连接数据库的信息
          -->
          <environments default="development">
              <environment id="development">
                  <transactionManager type="JDBC"/>
                  <!--
                      dataSource type="POOLED"  表示使用数据库连接池
                  -->
                  <dataSource type="POOLED">
                      <property name="driver" value="com.mysql.jdbc.Driver"/>
                      <property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=UTF-8"/>
                      <property name="username" value="root"/>
                      <property name="password" value="root"/>
                  </dataSource>
              </environment>
          </environments>
      
          <!--
              mybatis   是把SQL语句放到配置文件中 , 而不是写到java类中
          -->
          <mappers>
              <mapper resource="com/atguigu/mapper/UserMapper.xml"/>
          </mappers>
      
      </configuration>
      
      6.编写Mapper接口
      package com.atguigu.mapper;
      
      import com.atguigu.pojo.User;
      
      public interface UserMapper {
      
          // 根据id 查询 用户信息
      
          public User selectUserById(Integer id);
      
      }
      
      7.配置UserMapper.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 就是映射  , 映射mapper接口和方法  和 SQL 语句的对应关系
              namespace : 名称空间 / 命名空间
                  必须是全类名
          -->
      <mapper namespace="com r">
      
          <!--
               public User selectUserById(Integer id);
      
                  select标签表示配置select查询语句
                  id是唯一标识.一定要跟mapper接口中的方法名一致
                  parameterType 属性表示参数类型( 可选设置,如果是JavaBean,推荐设置 )
                          parameterType="int"( 可省略 )
                  resultType 属性表示返回值的类型
      
                  #{id} 表示占位符参数 ?
          -->
          <select id="selectUserById" resultType="com.atguigu.pojo.User">
              select `id` , `last_name` lastName , `sex` from t_user where id = #{id}
          </select>
      
      </mapper>
      
      8.测试
      package com.atguigu.test;
      
      import com.atguigu.mapper.UserMapper;
      import com.atguigu.pojo.User;
      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 org.junit.Test;
      
      import java.io.IOException;
      import java.io.InputStream;
      
      public class MybatisTest {
      
          @Test
          public void selectUserById() throws IOException {
      		 //读取mybatis-config.xml配置文件
              InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
             
              SqlSessionFactory sqlSessionFactory  = new SqlSessionFactoryBuilder().build(resourceAsStream);
      		// 获取连接
              SqlSession sqlSession = sqlSessionFactory.openSession();
      
             try {
      			// 获取指定类型的Mapper接口实现类
                 UserMapper mapper = sqlSession.getMapper(UserMapper.class);
                 User user = mapper.selectUserById(1);
                 System.out.println(user);
      
             }finally {
                 sqlSession.close();
             }
          }
      }
      

3.返回主键自增 (插入并返回主键)

  • UserMapper.xml 配置
 <!--
     得到主键id
     useGeneratedKeys:得到数据库自增id
     keyProperty:表示pojo类中的映射field
     keyColumn: 字段名称  数据库
 -->
   <insert id="insertUser" parameterType="com.atguigu.pojo.User"
            useGeneratedKeys="true"  keyProperty="id" keyColumn="id">
        insert into t_user (`last_name`,`sex`) values (#{lastName},#{sex})
 </insert>
 

  • 标签的使用

  • 针对主键无法设置主键自增

    selectKey标签,它可以在语句的标签里面再定义一个查询语句。

    这个查询语句,主要用于查询生成的主键

       <!--
        使用 SELECT LAST_INSERT_ID(); 得到主键id
        selectKey:放入SELECT LAST_INSERT_ID()
        order:AFTER:表示insert 之后执行
        keyColumn:数据库 主键 名称
        keyProperty: java 中 field 名称
        resultType:指定主键类型
    -->
       <insert id="insertUser" parameterType="com.atguigu.pojo.User">
           <selectKey order="AFTER" keyProperty="id" keyColumn="id" resultType="integer">
               select last_insert_id()
           </selectKey>
           insert into t_user (`last_name` , `sex`) values (#{lastName},#{sex});
       </insert>
    

4.注解@MapKey的使用

@MapKey可以把返回的结果转换为map对象,

并指定一个属性做为key( key是唯一的,所以指定的属性值要唯一 )

  • Mapper接口:

       /**
         *      将查询出来的数据封装到Map中
         * @return
         */
        @MapKey("id")
        Map<Integer ,User> selectUserMap();
    }
    
  • 配置文件

    <!--
            Map<Integer ,User> selectUserMap();
    -->
    <select id="selectUserMap" resultType="User">
           select `id`  ,`last_name` lastName , sex from t_user
    </select>
    
  • 测试

    @Test
    public void selectUserMap() {
        Map<Integer, User> map = userMapper.selectUserMap();
        map.forEach((k,v) -> {
            System.out.println(k + "," + v);
        });
    

5.mybatis 的核心配置之properties

    <!--

        全局配置
            properties用来配置键值对
           resource属性指定加载的属性配置文件路径
    -->
    <properties resource="jdbc.properties">
<!--        <property name="password" value="root"/>-->
<!--        jdbc.password=root-->
    </properties>
  • jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=UTF-8
jdbc.username=root
jdbc.password=root

6.settings

*设置参数**描述**有效值**默认值*
cacheEnabled该配置影响的所有映射器中配置的缓存的全局开关。true | falsetrue
lazyLoadingEnabled延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置fetchType属性来覆盖该项的开关状态。true | falsefalse
aggressiveLazyLoading当启用时,对任意延迟属性的调用会使带有延迟加载属性的对象完整加载;反之,每种属性将会按需加载。true | falsetrue
multipleResultSetsEnabled是否允许单一语句返回多结果集(需要兼容驱动)。true | falsetrue
useColumnLabel使用列标签代替列名。不同的驱动在这方面会有不同的表现, 具体可参考相关驱动文档或通过测试这两种不同的模式来观察所用驱动的结果。true | falsetrue
useGeneratedKeys允许 JDBC 支持自动生成主键,需要驱动兼容。 如果设置为 true 则这个设置强制使用自动生成主键,尽管一些驱动不能兼容但仍可正常工作(比如 Derby)。true | falseFalse
autoMappingBehavior指定 MyBatis 应如何自动映射列到字段或属性。 NONE 表示取消自动映射;PARTIAL 只会自动映射没有定义嵌套结果集映射的结果集。 FULL 会自动映射任意复杂的结果集(无论是否嵌套)。NONE, PARTIAL, FULLPARTIAL
autoMappingUnknownColumnBehaviorSpecify the behavior when detects an unknown column (or unknown property type) of automatic mapping target.· NONE: Do nothing· WARNING: Output warning log (The log level of’org.apache.ibatis.session.AutoMappingUnknownColumnBehavior’must be set to WARN)· FAILING: Fail mapping (Throw SqlSessionException)NONE, WARNING, FAILINGNONE
defaultExecutorType配置默认的执行器。SIMPLE 就是普通的执行器;REUSE 执行器会重用预处理语句(prepared statements); BATCH 执行器将重用语句并执行批量更新。SIMPLE REUSE BATCHSIMPLE
defaultStatementTimeout设置超时时间,它决定驱动等待数据库响应的秒数。Any positive integerNot Set (null)
defaultFetchSizeSets the driver a hint as to control fetching size for return results. This parameter value can be override by a query setting.Any positive integerNot Set (null)
safeRowBoundsEnabled允许在嵌套语句中使用分页(RowBounds)。 If allow, set the false.true | falseFalse
safeResultHandlerEnabled允许在嵌套语句中使用分页(ResultHandler)。 If allow, set the false.true | falseTrue
mapUnderscoreToCamelCase是否开启自动驼峰命名规则(camel case)映射,即从经典数据库列名 A_COLUMN 到经典 Java 属性名 aColumn 的类似映射。true | falseFalse
localCacheScopeMyBatis 利用本地缓存机制(Local Cache)防止循环引用(circular references)和加速重复嵌套查询。 默认值为 SESSION,这种情况下会缓存一个会话中执行的所有查询。 若设置值为 STATEMENT,本地会话仅用在语句执行上,对相同 SqlSession 的不同调用将不会共享数据。SESSION | STATEMENTSESSION
jdbcTypeForNull当没有为参数提供特定的 JDBC 类型时,为空值指定 JDBC 类型。 某些驱动需要指定列的 JDBC 类型,多数情况直接用一般类型即可,比如 NULL、VARCHAR 或 OTHER。JdbcType enumeration. Most common are: NULL, VARCHAR and OTHEROTHER
lazyLoadTriggerMethods指定哪个对象的方法触发一次延迟加载。A method name list separated by commasequals,clone,hashCode,toString
defaultScriptingLanguage指定动态 SQL 生成的默认语言。A type alias or fully qualified class name.org.apache.ibatis.scripting.xmltags.XMLDynamicLanguageDriver
callSettersOnNulls指定当结果集中值为 null 的时候是否调用映射对象的 setter(map 对象时为 put)方法,这对于有 Map.keySet() 依赖或 null 值初始化的时候是有用的。注意基本类型(int、boolean等)是不能设置成 null 的。true | falsefalse
logPrefix指定 MyBatis 增加到日志名称的前缀。Any StringNot set
logImpl指定 MyBatis 所用日志的具体实现,未指定时将自动查找。SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGINGNot set
proxyFactory指定 Mybatis 创建具有延迟加载能力的对象所用到的代理工具。CGLIB | JAVASSISTJAVASSIST (MyBatis 3.3 or above)
vfsImplSpecifies VFS implementationsFully qualified class names of custom VFS implementation separated by commas.Not set
useActualParamNameAllow referencing statement parameters by their actual names declared in the method signature. To use this feature, your project must be compiled in Java 8 with -parameters option. (Since: 3.4.1)true | falsetrue

7.mybatis的核心配置

7.1mybatis 的核心配置之typeAliases

我们在编写sql的配置文件中,经常会出现大量的相同的全类名。

这些全类名都是一样的字符串,我们就可以给一个类型定义一个简短的别名。去使用这个别名表示一个具体的类型。

<!-- typeAliases定义多个别名 -->
<typeAliases>
    <!--
        type属性是全类名
        alias属性指定别名

    <typeAlias type="com.atguigu.mybatis.hello.pojo.User" alias="user"/>
    -->
    <!--
        指定包名,Mybatis会自动的扫描这个包下所有的类,自动映射别名
        别名,就是它的类名,或类名首字母小写
        com.atguigu.mybatis.hello.pojo.User   ====>>>  User 或 user
     -->
    <package name="com.atguigu.mybatis.hello.pojo"/>
    <package name="com.atguigu.mybatis.hello.domain"/>
</typeAliases>

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BbSGpzNS-1608194328342)(file:///C:\Users\psd\AppData\Local\Temp\ksohtml1752\wps1.jpg)]

7.2mybatis 的核心配置之typeHandlers
*类型处理器**Java 类型**JDBC 类型*
BooleanTypeHandlerjava.lang.Boolean, boolean数据库兼容的 BOOLEAN
ByteTypeHandlerjava.lang.Byte, byte数据库兼容的 NUMERIC 或 BYTE
ShortTypeHandlerjava.lang.Short, short数据库兼容的 NUMERIC 或 SHORT INTEGER
IntegerTypeHandlerjava.lang.Integer, int数据库兼容的 NUMERIC 或 INTEGER
LongTypeHandlerjava.lang.Long, long数据库兼容的 NUMERIC 或 LONG INTEGER
FloatTypeHandlerjava.lang.Float, float数据库兼容的 NUMERIC 或 FLOAT
DoubleTypeHandlerjava.lang.Double, double数据库兼容的 NUMERIC 或 DOUBLE
BigDecimalTypeHandlerjava.math.BigDecimal数据库兼容的 NUMERIC 或 DECIMAL
StringTypeHandlerjava.lang.StringCHAR, VARCHAR
ClobReaderTypeHandlerjava.io.Reader-
ClobTypeHandlerjava.lang.StringCLOB, LONGVARCHAR
NStringTypeHandlerjava.lang.StringNVARCHAR, NCHAR
NClobTypeHandlerjava.lang.StringNCLOB
BlobInputStreamTypeHandlerjava.io.InputStream-
ByteArrayTypeHandlerbyte[]数据库兼容的字节流类型
BlobTypeHandlerbyte[]BLOB, LONGVARBINARY
DateTypeHandlerjava.util.DateTIMESTAMP
DateOnlyTypeHandlerjava.util.DateDATE
TimeOnlyTypeHandlerjava.util.DateTIME
SqlTimestampTypeHandlerjava.sql.TimestampTIMESTAMP
SqlDateTypeHandlerjava.sql.DateDATE
SqlTimeTypeHandlerjava.sql.TimeTIME
ObjectTypeHandlerAnyOTHER 或未指定类型
EnumTypeHandlerEnumeration TypeVARCHAR-任何兼容的字符串类型,存储枚举的名称(而不是索引)
EnumOrdinalTypeHandlerEnumeration Type任何兼容的 NUMERIC 或 DOUBLE 类型,存储枚举的索引(而不是名称)。
7.3mybatis 的核心配置之encironments
 <environments default="dev">
        <environment id="dev">
            <!--
        transactionManager 表示事务管理器
            type属性指定使用哪个事物管理器
                JDBC            有事务管理,有提交和有回滚
                MANAGED         事务交给容器管理,没提交,也回滚
    -->
            <transactionManager type="JDBC"/>
<!--
            <transactionManager type="MANAGED">
                <property name="closeConnection" value="false"/>
            </transactionManager>

            -->

            <!--
             dataSource:数据源,连接池
             POOLED:就表示使用mybatis内置的连接池
         -->


            <dataSource type="POOLED">
                <!--数据库的必要属性-->
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>

7.4mybatis 的核心配置之databaseld

MyBatis 可以根据不同的数据库厂商执行不同的语句,这种多厂商的支持是基于映射语句中的 databaseId 属性。 MyBatis 会加载不带 databaseId 属性和带有匹配当前数据库 databaseId 属性的所有语句。

​ <databaseIdProvider type=“DB_VENDOR”>

​ <property name=“SQL Server” value=“sqlserver” />

​ <property name=“MySQL” value=“mysql” />

​ <property name=“DB2” value=“db2” />

​ <property name=“Oracle” value=“oracle” />

mybatis提供了一个类VendorDatabaseIdProvider,中的getDatabaseId() 方法用于获取数据库的标识。

property 标签name属性是获取数据库ID标识。

property 标签value属性是我们给mybatis定义的一个简短的标识。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值