一、SqlSession的使用范围说明

 1、SQLSessionFactoryBuilder

  通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory,将SqlSessionFactoryBuilder当成一个工具类使用即可,不需要使用单例模式管理,在创建SqlSessionFactory的时候,只需要new一次SqlSessionFactoryBuilder即可。

 2、SqlSessionFactory

  通过SqlSessionFactory创建SqlSession,使用单例模式来管理SqlSessionFactory(工厂一旦创建,只使用一个实例)。

 3、SqlSession

  SqlSession是一个面向用户(程序员)的接口。
  SqlSession中提供了很多操作数据库的方法:如selectOne(返回单个对象)、selectList(返回单个或多个对象)。
  SqlSession是线程不安全的,因为在SqlSession中除了有接口中的方法(操作数据库的方法)之外。还有数据域属性。
  SqlSession的最佳应用场合是在方法体内,将其定义为局部变量来使用。

二、SqlMapConfig.xml配置文件详解

 1、Properties属性

  Properties属性用来加载属性配置文件。

 <!--

        加载属性文件

        resource:属性文件的相对路径

        url:属性文件的绝对路径

     -->

    <properties resource="config/db.properties">

        <!--

            配置一些属性

            name:属性的名称

            value:属性的值

        -->

        <!--<property name="" value="" /> -->

    </properties>

  

  properties特性:
   Mybatis将按照下面的属性来加载属性:
   1. 首先会读取在property标签中定义的属性。
   2. 然后会读取在properties标签中通过resource或url加载时的属性,它会覆盖已读取得同名属性。
   3. 最后会读取sql中parameterType传递过来的属性,它会覆盖已读取的同名属性。

  2、settings全局参数配置

  Mybatis框架在运行时可以调整一些运行参数,比如:开启二级缓存、开启延迟加载等。这些参数要通过settings标签来配置,全局参数会影响Mybatis的运行行为,配置一定要注意。

  常用的全局配置参数如下:

<!--全局参数配置-->

    <settings >

            <!--

                name:属性名称

                value:属性的值

            -->

        <setting name="" value=""/>

    </settings>

  

3、typeAlia

  在映射文件中的parameterType和resultType属性中要指定输入、输出映射类型,如果类型为PO,要指定PO类的全路径这样不是特别方便,可以使用typeAlias定义一些别名,来方便开发。

<!--定义别名-->

    <typeAliases>

        <!--

            type:需要起别名的字符串

            alias:对应的别名

        -->

        <typeAlias type="" alias="" />

        <!--

            name:包名,会对包下面的类进行扫描,自动批量设置别名,

                设置的别名为类名,首字母大小写均可

        -->

        <package name="" />

    </typeAliases>

  Mybatis的默认别名

  

 4、typeHandlers(类型处理器)

  Mybatis中通过typeHandlers完成jdbc类型和Java类型的装换。通常情况下,Mybatis提供的类型处理器满足日常需要,不需要我们再自定义。

<typeHandlers>

        <typeHandler handler="" jdbcType="" javaType="" />

    </typeHandlers>

  Mybatis默认支持的数据类型

  

5、environments 环境

<!--

        环境配置

        在和Spring整合后改配置将废除

    -->

    <environments default="development">

        <environment id="development">

            <!--使用JDBC的事务管理,事务管理交给Mybatis-->

            <transactionManager type="JDBC"></transactionManager>

            <!--数据库连接池,有Mybatis管理-->

            <dataSource type="POOLED">

                <property name="driver" value="com.mysql.jdbc.Driver" />

                <property name="url" value="jdbc:mysql://localhost:3306/mybatis" />

                <property name="username" value="root" />

                <property name="password" value="root" />

            </dataSource>

        </environment>

</environments>

  

6、mapper 加载映射文件

  加载映射文件有三种方式

  1、加载单个映射文件

 <!--引入mapper-->

    <mappers>

        <!--rerource:引入映射文件相对于classpath的地址-->

        <mapper resource="config/sqlmap/userMapper.xml" />

</mappers>

  

 2、通过Mapper接口加载单个映射文件
  前提条件:
   (1). 使用Mapper代理的方式进行开发。
   (2). Mapper接口文件名要和映射文件名一致
   (3).Mapper接口文件和映射文件在同一个目录下

 <!--引入mapper-->

    <mappers>

        <mapper class="com.jack.po.UserMapper" />

</mappers>

  

  3、批量记载映射文件
  前提条件:
   (1). 使用Mapper代理的方式进行开发。
   (2). Mapper接口文件名要和映射文件名一致
   (3).Mapper接口文件和映射文件在同一个目录下

  <!--引入mapper-->

    <mappers>

        <!--name:mapper接口文件所在的包路径-->

      <package name="" />

    </mappers>

  本文来自上海尚学堂Java学员原创

Mybatis配置详解的更多相关文章

  1. 一、Mybatis配置详解

    Mybatis配置详解 XML配置文件层次结构 下图展示了mybatis-config.xml的全部配置元素 properties元素 properties是一个配置属性的元素,让我们能在配置文件的上 ...

  2. spring mvc+myBatis配置详解

    一.spring mvc Spring框架(框架即:编程注解+xml配置的方式)MVC是Spring框架的一大特征,Spring框架有三大特征(IOC(依赖注入),AOP(面向切面),MVC(建模M- ...

  3. Spring Boot整合Mybatis配置详解

    首先,你得有个Spring Boot项目. 平时开发常用的repository包在mybatis里被替换成了mapper. 配置: 1.引入依赖: <dependency> <gro ...

  4. 深入浅出Mybatis系列(四)---配置详解之typeAliases别名(mybatis源码篇)

    上篇文章<深入浅出Mybatis系列(三)---配置详解之properties与environments(mybatis源码篇)> 介绍了properties与environments, ...

  5. mybatis 代码生成器(IDEA, Maven)及配置详解(部分配置你应该不知道)

    目录 1 创建代码生成器 1.1 创建Maven项目 1.2 配置 generator.xml 1.3 配置 pom.xml 1.4 使用及测试 2 XML 配置详解 2.1 优先 2.2 官网没有的 ...

  6. 转载 Spring、Spring MVC、MyBatis整合文件配置详解

    Spring.Spring MVC.MyBatis整合文件配置详解   使用SSM框架做了几个小项目了,感觉还不错是时候总结一下了.先总结一下SSM整合的文件配置.其实具体的用法最好还是看官方文档. ...

  7. Spring MVC、MyBatis整合文件配置详解

    Spring:http://spring.io/docs MyBatis:http://mybatis.github.io/mybatis-3/ Building a RESTful Web Serv ...

  8. Mybatis中接口和对应的mapper文件位置配置详解

    Mybatis中接口和对应的mapper文件位置配置详解 原链接为:https://blog.csdn.net/fanfanzk1314/article/details/71480954 今天遇到一个 ...

  9. 深入浅出Mybatis系列四-配置详解之typeAliases别名(mybatis源码篇)

    注:本文转载自南轲梦 注:博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 上篇文章<深入浅出Mybatis系列(三)---配置详解之properties ...

随机推荐

  1. pydev 下Django 1.7 undefined variables from import问题的解决

    参考:http://stackoverflow.com/questions/24951029/pydev-django-undefined-variables-from-import 参考上面的帖子认 ...

  2. Grunt的配置和使用

    Grunt和Grunt插件是通过NodeJs的包管理工具npm安装并进行管理的. Grunt 0.4.x必须配合NodeJs=>0.8.0版本使用(奇数版本的NodeJs不是稳定的开发版本)   ...

  3. C++中遍历读取数组中的元素

    答案来源:https://zhidao.baidu.com/question/187071815.html 对于字符数组str[N],判断方法有以下三种: 第一种:用库函数strlen 1 len = ...

  4. .net core使用Ku.Core.Extensions.Layui实现layui表单渲染

    演示网站地址:http://layui.kulend.com/项目地址:https://github.com/kulend/Ku.Core.Extensions/tree/master/Ku.Core ...

  5. nginx安装配置+集群tomcat:Centos和windows环境

    版本:nginx-1.8.0.tar.gz 官网:http://nginx.org/en/download.html         版本:apache-tomcat-6.0.44.tar.gz  官 ...

  6. HTML学习笔记6:列表标签

    列表标签     什么是列表标签呢? 以平台区分有什么游戏? 手游 pc游戏 家用机游戏 掌机游戏 以游戏类型区分有什么游戏? RPG ARPG MMORPG ACT FPS 以上两种就是一种列表标签 ...

  7. Flask入门之SQLAlchemy数据库连接操作(第15讲)

    一.库安装 Flask-SQLAlchemy 2 SQLAlchemy 1.0.8 二.进入venv 三.切换到项目Sample\ 文件夹,进入manager.py 的shell python man ...

  8. ubuntu 16.04安装smatrgitHG工具

    SmartGit/HG 是一款开放源代码的.跨平台的.支持 Git 和 Mercurial 的 SVN 图形客户端,可运行在Windows.Linux 和 MAC OS X 系统上. 1.安装 Ubu ...

  9. vue 使用踩坑 note

    1. 如图,假如large那一行错写成 'large': item.ext_data.isLarge + '' === 'true',, 那么,编译不报错,控制台无提示,模板不输出. 2. vue的t ...

  10. mysql explain rows理解

    在MySQL性能调试中,常常使用EXPLAIN解释MySQL执行计划,从而用来估算性能耗时.其中,rows用来表示在SQL执行过程中会被扫描的行数,该数值越大,意味着需要扫描的行数,相应的耗时更长.但 ...