包含mybatis是谁发明的的词条

本篇文章给大家谈谈mybatis是谁发明的,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

文章目录:

什么是mybatis 为什么要使用my batis

1、定义

MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。

2、使用原因

MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配带卖置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库租弯中的记录。

3、总体流程

(1)加载配置并初始化

触发条件:加载配置文件

处理过程:将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。

(2)接收调用请求

触发条件:调用Mybatis提供的API

传入参数:为SQL的ID和传入参数对象

处理过程:将请求传递给下层的请求处理层进行处理。

(3)处理操作请求

触发条件:API接口层传递请求过来

传入参数:为SQL的ID和传入参数对象

处理过程:

(A)根据SQL的ID查找对应的MappedStatement对象。

(B)根据传入参数对象解析MappedStatement对象,得到最终要执行的SQL和执行传入参数。

(C)获取数据库连接,根据得到的最终SQL语句和执行传入参数到数据库执行,并得到执行结果。

(D)根据MappedStatement对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果。

(E)释放连接资源。

(4)返回处理结果将最终的处理结弊行闷果返回。

mybatis+druid+jdbc 原理介绍

mybatis是警察.

druid是武器库(有很多枪).

jdbc是武器商(他们造枪给武器库).

当你需要一次"除暴安良"时,你需要去找警察,警察从武器库拿枪干活.

以往的开发,是你使用jdbc直接造枪,然后自己干活.

jdbc整合了:加载数据库驱动,创建连接,写原生语句,执行,关闭这些东西.

而mybatis是对jdbc的封装,他允许你通过配置的形式,配置数据库参数,并且允许你通过xml来写动态sql语句.if:test让你可以把sql变得灵活起来.并且还能将你的查询结果直接映射到你想要的实体上面.

然后你就去配置你的用户名,密码,连接超时,等等.

等你下次使用mybatis时,他后面会根据你的配置,帮你加载灶局数据库驱动,创裂哗建连接,写原生语句,执行,关闭.

但是mybatis发现,在你每次访问都要重新创建创建连接,写,关.很麻烦,所以mybatis说,我可以接受你再配置一个连接池,比如druid.

mybatis让你指定连接池是谁,如druid.之后将原来自己需要搞的东西都交给druid.什么账号了,密码了.都给他,让druid帮你创建一批连接,在你需要用隐源让的时候,mybatis从druid里面拿一个就行.

下面是一次简单的访问流程:

controller-service-dao-mapper

1.首先项目启动时druid就已经使用jdbc创建好一堆连接了,留待后用.

2.当请求到mapper时,mybatis框架创建临时类.

3.然后将动态sql进行替换重写,变成原始的native sql.

4.从druid拿到一个连接.

5.将sql通过连接交给数据库执行.

6.然后获取执行结果.

7.mybatis进行将结果进行映射,返回数据.

说的有点乱,希望能说清楚吧...

mybatis是什么

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。

MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。消枣铅MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

每拿好个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。SqlSessionFactoryBuilder可以从一个xml配置文岩毕件或者一个预定义的配置类的实例获得。

通过上述对mybatis是谁发明的和的解读,相信您一定有了深入的理解,如果未能解决您的疑问,可在评论区留言哟。

版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

分享:

扫一扫在手机阅读、分享本文

评论