Mybatis有什么用

技术Mybatis有什么用这篇文章将为大家详细讲解有关Mybatis有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介MyBatis的前身叫iBatis,本是apache的一个

本文将详细解释Mybatis的使用。边肖觉得挺实用的,就分享给大家参考。希望你看完这篇文章能有所收获。

简介

MyBatis的前身是iBatis,最初是apache的开源项目。2010年,这个项目从apache软件基金会转移到谷歌代码,并改名为MyBatis。MyBatis是一个优秀的持久层框架,支持普通的SQL查询、存储过程和高级映射。MyBatis消除了几乎所有JDBC代码和参数的手动设置以及结果集的检索。MyBatis使用简单的XML或注释进行配置和原始映射,并将接口和Java POJO(Plan Old Java Objects)映射到数据库中的记录。

Mybatis的功能架构分为三层(图片借用百度百科):

1)API接口层:提供给外部使用的接口API,开发人员可以通过这些本地API对数据库进行操作。接口层收到调用请求后,会调用数据处理层完成具体的数据处理。

2)数据处理层:负责具体的SQL搜索、SQL分析、SQL执行和执行结果映射等。它的主要目的是根据被调用的请求完成一个数据库操作。

3)基础支持层:负责最基础的功能支持,包括连接管理、事务管理、配置加载和缓存处理。这些都是常见的东西,它们被提取出来作为最基本的组成部分。为上层数据处理层提供最基本的支持。

Mybatis有什么用

快速入门

Mybatis有什么用

Mybatis总体流程图

SqlSessionFactoryBuilder

MyBatis的每个应用的入口都是SqlSessionFactoryBuilder,用来通过XML配置文件创建Configuration对象(当然也可以在程序中自己创建),然后通过build方法创建SqlSessionFactory对象。没有必要每次访问Mybatis都创建SqlSessionFactoryBuilder。通常的做法是创建一个全局对象。示例过程如下:

[java]景观平面图

privatedstatisqlsessionfactorybuilders qlssessionfactorybuilder;

privatedstatisqlsessionfactory;

privatedstationinit()throwSioException {

string source=' my batis-config . XML ';

reader reader=resources . getresourceasreader(资源);

sqlSessionFactoryBuilder=newnb

sp;SqlSessionFactoryBuilder();  

  •     sqlSessionFactory = sqlSessionFactoryBuilder.build(reader);  

  • }  

  • SqlSessionFactory

    SqlSessionFactory对象由SqlSessionFactoryBuilder创建。它的主要功能是创建SqlSession对象,和SqlSessionFactoryBuilder对象一样,没有必要每次访问Mybatis就创建一次SqlSessionFactory,通常的做法是创建一个全局的对象就可以了。SqlSessionFactory对象一个必要的属性是Configuration对象,它是保存Mybatis全局配置的一个配置对象,通常由SqlSessionFactoryBuilder从XML配置文件创建。这里给出一个简单的示例:

    [html] view plain copy

    1. <?xml version="1.0" encoding="UTF-8" ?>  

    2. <!DOCTYPE configuration PUBLIC   

    3.     "-//mybatis.org//DTD Config 3.0//EN"  

    4.     "http://mybatis.org/dtd/mybatis-3-config.dtd">  

    5. <configuration>  

    6.     <!-- 配置别名 -->  

    7.     <typeAliases>  

    8.         <typeAlias type="org.iMybatis.abc.dao.UserDao" alias="UserDao" />  

    9.         <typeAlias type="org.iMybatis.abc.dto.UserDto" alias="UserDto" />  

    10.     </typeAliases>  

    11.        

    12.     <!-- 配置环境变量 -->  

    13.     <environments default="development">  

    14.         <environment id="development">  

    15.             <transactionManager type="JDBC" />  

    16.             <dataSource type="POOLED">  

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

    18.                 <property name="url" value="jdbc:mysql://127.0.0.1:3306/iMybatis?characterEncoding=GBK" />  

    19.                 <property name="username" value="iMybatis" />  

    20.                 <property name="password" value="iMybatis" />  

    21.             </dataSource>  

    22.         </environment>  

    23.     </environments>  

    24.       

    25.     <!-- 配置mappers -->  

    26.     <mappers>  

    27.         <mapper resource="org/iMybatis/abc/dao/UserDao.xml" />  

    28.     </mappers>  

    29.       

    30. </configuration>  

    要注意XML头部的声明,需要用来验证XML文档正确性。typeAliases 元素是包含所有typeAlias(别名)的列表,别名用来替换完整类名,这样在需要完整类名的地方就可以用别名来代替。environment元素体中包含对事务管理和连接池的环境配置。mappers元素是包含所有mapper(映射器)的列表,这些mapper的XML文件包含SQL代码和映射定义信息。当然,在XML配置文件中还有很多可以配置的,上面的示例指出的则是最关键的部分,其他配置请参考Mybatis的官方文档。

    SqlSession

    SqlSession对象的主要功能是完成一次数据库的访问和结果的映射,它类似于数据库的session概念,由于不是线程安全的,所以SqlSession对象的作用域需限制方法内。SqlSession的默认实现类是DefaultSqlSession,它有两个必须配置的属性:Configuration和Executor。Configuration前文已经描述这里不再多说。SqlSession对数据库的操作都是通过Executor来完成的,Executor的具体功能在下一小节在描述。

    到目前为止,我们看到的都是mybatis的流程,我们的应用程序在什么地方插入到这个流程中并获得我们想要的结果呢?就是SqlSession这里。SqlSession有一个重要的方法getMapper,顾名思义,这个方式是用来获取Mapper对象的。什么是Mapper对象?根据Mybatis的官方手册,应用程序除了要初始并启动Mybatis之外,还需要定义一些接口,接口里定义访问数据库的方法,存放接口的包路径下需要放置同名的XML配置文件。SqlSession的getMapper方法是联系应用程序和Mybatis纽带,应用程序访问getMapper时,Mybatis会根据传入的接口类型和对应的XML配置文件生成一个代理对象,这个代理对象就叫Mapper对象。应用程序获得Mapper对象后,就应该通过这个Mapper对象来访问Mybatis的SqlSession对象,这样就达到里插入到Mybatis流程的目的。示例代码如下:

    [java] view plain copy

    1. SqlSession session= sqlSessionFactory.openSession();  

    2. UserDao userDao = session.getMapper(UserDao.class);  

    3. UserDto user = new UserDto();  

    4. user.setUsername("iMybatis");  

    5. List<UserDto> users = userDao.queryUsers(user);  

    对应的接口:

    [java] view plain copy

    1. public interface UserDao {  

    2.     public List<UserDto> queryUsers(UserDto user) throws Exception;  

    3. }  

    对应的配置文件:

    [html] view plain copy

    1. <?xml version="1.0" encoding="UTF-8" ?>  

    2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">  

    3. <mapper namespace="org.iMybatis.abc.dao.UserDao">  

    4.     <select id="queryUsers" parameterType="UserDto" resultType="UserDto"  

    5.         useCache="false">  

    6.         <![CDATA[ 

    7.         select * from t_user t where t.username = #{username} 

    8.         ]]>  

    9.     </select>  

    10. </mapper>  

    Executor

    Executor对象在创建Configuration对象的时候创建,并且缓存在Configuration对象里。Executor对象的主要功能是调用StatementHandler访问数据库,并将查询结果存入缓存中(如果配置了缓存的话)。

    StatementHandler

    StatementHandler是真正访问数据库的地方,并调用ResultSetHandler处理查询结果。

    ResultSetHandler

    处理查询结果

    关于“Mybatis有什么用”这篇文章就分享到这里了,希望

    内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/116459.html

    (0)

    相关推荐

    • 时间的问题总结

      技术时间的问题总结 时间的问题总结要点
      1、数据库时间,实体和Mybatis数据类型之间的对应关系
      2、前端传日期还是字符串
      3、时间格式化(用注解的方式如何去写,出参、入参如何格式化)
      4、大于、小于

      礼包 2021年12月14日
    • mysql中动态语句编写的引号怎么用

      技术mysql中动态语句编写的引号怎么用这篇文章主要为大家展示了“mysql中动态语句编写的引号怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql中动态语句编写的

      攻略 2021年11月2日
    • 抖音刷赞软件,实惠的刷赞软件

      技术抖音刷赞软件,实惠的刷赞软件免费刷抖音赞软件,抖音怎么刷点赞上热门?关于抖音刷赞、抖音怎么刷赞等相关问题,于是去网上输入”抖音刷赞”,哇~不搜不知道一搜吓一跳,网上出现:抖音刷赞|抖音怎么刷赞|抖音刷赞上热门|抖音快

      测评 2021年10月19日
    • fabricca配置文件详细说明(fabric-ca设置账户使用期限)

      技术Fabric CA创建用户机制的示例分析这篇文章给大家分享的是有关Fabric CA创建用户机制的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在研究Fabric CA 创建用户,

      攻略 2021年12月25日
    • go环境变量怎么配置

      技术go环境变量怎么配置这篇文章将为大家详细讲解有关go环境变量怎么配置,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。export GOROOT=/usr/local/goexport

      攻略 2021年11月18日
    • html5新增标签是什么(html5视频标签是哪个)

      技术html5视频标签是哪个小编给大家分享一下html5视频标签是哪个,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

      攻略 2021年12月17日