会话获取

SqlSessionFactory

最佳的获取方式就是使用Mybatis提供的资源类加载配置文件

调用会话工厂建造者实例的建造方法注入读取流

要注意的是建造者生成了了实例就可以不需要了

这里我们可以使用null赋值,让指针解除引用,引导GC回收建造者实例

获取的SqlSessionFactory有且只需要一个且一直存在

那就是单例模式,保持在这个运行的范围内即可

在获取SqlSession,加入事务开关按钮

我们在环境标签配置的事务管理类型是JDBC,默认是开启的

在封装获取方法openSession时,可以注入布尔参数,

以灵活设置是否关闭事务

MybatisUtil调整后的写法:

public class MybatisUtil {

    private static org.apache.ibatis.session.SqlSessionFactory sqlSessionFactory;

    static {

        try{
// 核心配置文件名称
String config = "mybatis-config.xml"; // 读取核心配置 加载进内存为读取流对象
java.io.InputStream inputStream = org.apache.ibatis.io.Resources.getResourceAsStream(config); // 通过工场建造者获取了配置流对象,读取配置信息后,生成会话工厂实例
org.apache.ibatis.session.SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new org.apache.ibatis.session.SqlSessionFactoryBuilder();
sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream); // 销毁,让引用失去指向,引导GC回收
sqlSessionFactoryBuilder = null;
} catch (Exception exception){
exception.printStackTrace();
}
} // 获取会话实例即可
public static org.apache.ibatis.session.SqlSession getSqlSession(boolean closeTransaction){
return sqlSessionFactory.openSession(closeTransaction);
}
}

执行SQL时自行选择是否关闭事务

    @Test
public void quickstartMybatis(){
SqlSession sqlSession = MybatisUtil.getSqlSession(true);
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
List<User> userList = mapper.getUserList();
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}

配置 Configure

我们快速入门使用的是直接写在核心配置里的方式

官方讲Properties时

允许我们可以使用properties标签导入外部properties文件

注入环境的连接参数使用【${key}】读取

properties标签本身也能支持连接参数的配置

但是这和环境内配置有什么区别?

然后在优先级别中的位置是最低的,

如果外部配置文件读取错误,一样报错

总而言之:可以写,但是没必要

官方还推荐了一种默认占位符的方式配置,

就是说可以写个默认配置

但是者需要properties标签开启设置

<properties resource="org/mybatis/example/config.properties">
<!-- ... -->
<property name="org.apache.ibatis.parsing.PropertyParser.enable-default-value" value="true"/> <!-- 启用默认值特性 -->
</properties>

在这里我注释了用户密码,然后在配置里使用默认占位符设置

运行还是一样可行的

OGNL 表达式的三元运算符

(如: ${tableName != null ? tableName : 'global_constants'}

需要设置特定的属性来修改分隔属性名和默认值的字符。例如:

<properties resource="org/mybatis/example/config.properties">
<!-- ... -->
<property name="org.apache.ibatis.parsing.PropertyParser.default-value-separator" value="?:"/> <!-- 修改默认值的分隔符 -->
</properties>

类型别名(typeAliases)

说明一下XML约束

如果不按照规定的顺序写配置标签,就会有这样的错误提示

这个提示已经说明了,各种配置标签的先后顺序

第一种别名:指定完整限定名,然后配置别名

不推荐使用这种,因为类数量太多,配置麻烦

第二种,限定所在包

该包下的类的别名即为小写,例如User -> user

每一个在包 domain.blog 中的 Java Bean,在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。

比如 domain.blog.Author 的别名为 author

若有注解,则别名为其注解值。

映射器注册(mappers)

第一种,resource属性资源引用

要注意的是只能使用反斜杠作为分隔符,用点引用的路径会报错

好处是不用跟接口放在一起,随意使用

第二种通过接口完整限定名反射Mapper

必须和接口同一包下,且接口名和Mapper配置同名

第三种使用包扫描

这个问题和第二个一样,必须同包同名才有效

总而言之:

如果不希望Mapper配置和接口放在一起,

只能使用第一种资源引用方式,放在resoures的mapper中,或者自定义目录

第二种&第三种必须要同包同名

【Mybatis】06 Session获取 & 配置参数总结的更多相关文章

  1. Mybatis 学习---${ }与#{ }获取输入参数的区别、Foreach的用法

    一.Mybatis中用#{}和${}获取输入参数的区别 1.“#{}“和“${}”都可以从接口输入中的map对象或者pojo对象中获取输入的参数值.例如 <mapper namespace=&q ...

  2. python 使用getopt 获取配置参数

    在工程中特别是稍微大一点的项目基本上都会用到配置,就会涉及到配置文件的读取,配置参数的读取. 常用的解析配置文件的是configParser,解析命令行参数的则为getopt. getopt的参数可以 ...

  3. 开发笔记-19/10/28 -SpringBoot @Value 获取配置参数

    1. 在application.properties 定义参数 role.taskEvent :参数名称 4:值 ## ---------------------任务角色--------------- ...

  4. Crystal框架配置参数加载机制详解?

    前言 定义 配置参数定义的形式 配置参数文件定义在哪里? 配置参数加载的优先级 如何使用配置参数? 最佳实践 Jar项目中如何定义配置参数? War项目中如何定义或重载Jar包中的配置参数? 开发人员 ...

  5. Windows API获取系统配置文件的配置参数

    在Windows平台下获取系统配置文件(如:System.ini)的配置参数. 系统配置文件System.ini的内容如下: [SYSTEM] ServiceIP = 10.128.11.99:600 ...

  6. 【坑】Mybatis原始获取配置方式,获取配置失败

    错误环境: mysql版本:6.0.6 mybatis 3.4.1 idea 2017.1.2 maven 3.5.0 错误描述: 配置经路径见图1,classpath是java文件夹 获取配置的代码 ...

  7. 【SpringCloud】Gateway 配置全局过滤器获取请求参数和响应值

    [SpringCloud]Gateway 配置全局过滤器获取请求参数和响应值 实现Ordered接口getOrder()方法,数值越小越靠前执行,记得这一点就OK了. 获取请求参数RequestBod ...

  8. 【转】spring boot application.properties 配置参数详情

    multipart multipart.enabled 开启上传支持(默认:true) multipart.file-size-threshold: 大于该值的文件会被写到磁盘上 multipart. ...

  9. MyBatis笔记二:配置

    MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...

  10. 使用Mybatis的一些基本配置及Mybatis与数据库交互测试验证

    1.简介 什么是MyBatis? MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.My ...

随机推荐

  1. 绘图与可视化--pandas中的绘图函数

    matplotlib API函数都位于matplotlib.pyplot模块中. 本节代码中引入的约定为:import matplotlib.pyplot as plt numpy库也会用到,约定:i ...

  2. INFINI Labs 产品更新 | Console 告警中心 UI 全新改版,新增 Dashboard 全屏模式等功能

    本次 INFINI Labs 产品更新主要发布 Console v1.7.0,重点优化了 Console 告警中心和数据看板 Dashboard 可视化功能.详细介绍如下: 优化告警中心 UI 上个版 ...

  3. Tomcat问题修复系列之后台缓存不足

    系统运维时,在tomcat窗口发现一个警告 后台缓存收回进程无法释放上下文的缓存的10%-请考虑增加缓存的最大大小.在逐出之后,缓存中约保留XXX KB的数据. 无法将位于[/WEB-INF/view ...

  4. redis简单应用demo - 订单号自增长的思路:业务编码+地区+自增数值

    redis简单应用demo1.字符串127.0.0.1:6379> set hello toneyOK127.0.0.1:6379> type hellostring127.0.0.1:6 ...

  5. 实验四:WinRAR漏洞

    [实验目的] 通过打开rar文件,获取到目标机shell. [知识点] winrar漏洞 [实验原理] 该漏洞是由于WinRAR所使用的一个陈旧的动态链接库UNACEV2.dll所造成的,该动态链接库 ...

  6. 上交大开源镜像站下架 Docker Hub 镜像

    ​ 在现代软件开发中,Docker镜像已经成为不可或缺的工具.然而,最近频频出现的Docker镜像下架事件让许多开发者措手不及.突然失去依赖的镜像,不仅打乱了项目进程,还引发了许多不便.那么,面对Do ...

  7. 为什么有些IP无法PING通但又能访问

    背景 在调试板子的网络,突然发现板子无法ping通开发机(出现request timed out,),而电脑却可以ping通板子. 而scp.ssh以及nfs等工具却可以正常使用. 原理 找了一些资料 ...

  8. 使用iperf3调试网络

    介绍 Iperf是一款基于TCP/IP和UDP/IP的网络性能测试工具,它可以用来测量网络带宽和网络质量,还可以提供网络延迟抖动.数据包丢失率.最大传输单元等统计信息.网络管理员可以根据这些信息了解并 ...

  9. (sql语句试题练习及 参考答案解题思路+个人解题思路)

    SQL字段说明及数据 ======================================================================= 一.部门表字段描述:dp_no 部 ...

  10. 一文为你深度解析LLaMA2模型架构

    本文分享自华为云社区<[云驻共创]昇思MindSpore技术公开课 大咖深度解析LLaMA2 模型架构>,作者: Freedom123. 一.前言 随着人工智能技术的不断发展,自然语言处理 ...