欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mybatis调用存储过程详解(mybatis存储过程写法)

程序员文章站 2023-11-17 14:18:16
简述本文主要介绍mybatis框架工作原理及流程。mybatis介绍mybatis是一款优秀的持久层框架,它支持自定义sql、存储过程以及高级映射。mybatis免除了几乎所有的jdbc代码以及设置参...

简述

本文主要介绍mybatis框架工作原理及流程。

mybatis介绍

mybatis是一款优秀的持久层框架,它支持自定义sql、存储过程以及高级映射。mybatis免除了几乎所有的jdbc代码以及设置参数和获取结果集的工作。mybatis可以通过简单的xml或注解来配置和映射原始类型、接口和javapojo(plainoldjavaobjects,普通老式java对象)为数据库中的记录。

mybatis架构图

mybatis调用存储过程详解(mybatis存储过程写法)

图1 mybatis架构图

核心类

sqlsessionfactorybuilder:这个类可以被实例化、使用和丢弃,一旦创建了 sqlsessionfactory,就不再需要它了。因此sqlsessionfactorybuilder实例的最佳作用域是方法作用域(也就是局部方法变量)。你可以重用sqlsessionfactorybuilder来创建多个 sqlsessionfactory实例,但最好还是不要一直保留着它,以保证所有的 xml 解析资源可以被释放给更重要的事情。

sqlsessionfactory:sqlsessionfactory一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。使用sqlsessionfactory的最佳实践是在应用运行期间不要重复创建多次,多次重建sqlsessionfactory被视为一种代码”坏习惯”。因此sqlsessionfactory的最佳作用域是应用作用域。有很多方法可以做到,最简单的就是使用单例模式或者静态单例模式。

sqlsession:每个线程都应该有它自己的sqlsession实例。sqlsession的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。绝对不能将sqlsession实例的引用放在一个类的静态域,甚至一个类的实例变量也不行。也绝不能将sqlsession实例的引用放在任何类型的托管作用域中,如servlet框架中的httpsession。如果你现在正在使用一种web框架,考虑将sqlsession放在一个和http请求相似的作用域中。换句话说,每次收到http请求,就可以打开一个sqlsession,返回一个响应后,就关闭它。这个关闭操作很重要,为了确保每次都能执行关闭操作,你应该把这个关闭操作放到finally块中。

executor:executor(执行器)接口有两个实现类,其中baseexecutor有三个继承类分别是batchexecutor(重用语句并执行批量更新),reuseexecutor(重用预处理语句prepared statement,跟simple的唯一区别就是内部缓存statement),simpleexecutor(默认,每次都会创建新的statement)。

mapped statement:用来存放我们sql映射文件中的信息包括sql语句,输入参数,输出参数等等。一个sql节点对应一个mappedstatement对象。

工作流程

首先解释下两个文件

mybatis-config.xml:全局配置文件,引入了数据源、事务等mybatis运行环境;

mapper.xml:配置映射文件,配置sql结果集封装类型、传参类型;

1、 解析配置文件(mybatis-config.xml、mapper.xml),mybatis基于xml配置文件生成configuration,和一个个mappedstatement(包括了参数映射配置、动态sql语句、结果映射配置),其对应着<select | update | delete | insert>标签项。;

2、 sqlsessionfactorybuilder创建会话工厂sqlsessionfactory。

3、 sqlsessionfactory创建会话sqlsession;

4、 执行器将mappedstatement对象进行解析,sql参数转化、动态sql拼接,生成jdbc statement对象,使用paramterhandler填充参数,使用statementhandler绑定参数。

5、 jdbc执行sql,借助mappedstatement中的结果映射关系,使用resultsethandler将返回结果转化成hashmap、javabean等存储结构并返回。

6、 关闭sqlsession会话。

ok,以上就是mybatis工作原理及流程详细讲解,看完记得转发、点赞和收藏。想了解更多内容,请关注本小编,如果有错误,欢迎批评指正,感谢支持。