首页 > 其他分享 >mybatis学习第四部分: Mybatis配置⽂件深⼊

mybatis学习第四部分: Mybatis配置⽂件深⼊

时间:2022-11-19 22:12:29浏览次数:49  
标签:数据源 UserMapper id mybatis User sql Mybatis 第四 condition

4.1   核⼼配置⽂件SqlMapConfig.xml

4.1.1  MyBatis核⼼配置⽂件层级关系

 

 

 

4.2  MyBatis常⽤配置解析

1)environments标签

数据库环境的配置,⽀持多环境配置

其中,事务管理器(transactionManager)类型有两种:

•JDBC:这个配置就是直接使⽤了JDBC     的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作⽤域。

•MANAGED:这个配置⼏乎没做什么。它从来不提交或回滚⼀个连接,⽽是让容器来管理事务的整个⽣ 命周期(⽐如 JEE 应⽤服务器的上下⽂)。 默认情况下它会关闭连接,然⽽⼀些容器并不希望这样,因 此需要将 closeConnection 属性设置为 false 来阻⽌它默认的关闭⾏为。

其中,数据源(dataSource)类型有三种:

•UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。

•POOLED:这种数据源的实现利⽤“池”的概念将   JDBC  连接对象组织起来。

•JNDI:这个数据源的实现是为了能在如    EJB   或应⽤服务器这类容器中使⽤,容器可以集中或在外部配

置数据源,然后放置⼀个  JNDI  上下⽂的引⽤。

2)mapper标签

该标签的作⽤是加载映射的,加载⽅式有如下⼏种:

 

•使⽤相对于类路径的资源引⽤,例如:

<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>

•使⽤完全限定资源定位符(URL),例如:

<mapper url="file:///var/mappers/AuthorMapper.xml"/>

•使⽤映射器接⼝实现类的完全限定类名,例如:

<mapper class="org.mybatis.builder.AuthorMapper"/>

•将包内的映射器接⼝实现全部注册为映射器,例如:

<package name="org.mybatis.builder"/>

3)Properties标签

实际开发中,习惯将数据源的配置信息单独抽取成⼀个properties⽂件,该标签可以加载额外配置的properties⽂件

4)typeAliases标签

类型别名是为Java    类型设置⼀个短的名字。原来的类型名称配置如下

配置typeAliases,为com.lagou.domain.User定义别名为user

上⾯我们是⾃定义的别名,mybatis框架已经为我们设置好的⼀些常⽤的类型的别名

4.2 映射配置⽂件mapper.xml

动态sql语句 动态sql语句概述

Mybatis 的映射⽂件中,前⾯我们的 SQL 都是⽐较简单的,有些时候业务逻辑复杂时,我们的 SQL是 动态变化的,此时在前⾯的学习中我们的   SQL   就不能满⾜要求了。

参考的官⽅⽂档,描述如下:

 

我们根据实体类的不同取值,使⽤不同的     SQL语句来进⾏查询。⽐如在    id如果不为空时可以根据id查

询,如果username 不同空时还要加⼊⽤户名作为条件。这种情况在我们的多条件组合查询中经常会碰 到。

<select id="findByCondition" parameterType="user" resultType="user">
select * from User   <where>     <if test="id!=0"> and id=#{id}     </if>     <if test="username!=null"> and username=#{username}     </if>   </where> </select>

当查询条件id和username都存在时,测试代码如下:

//获得MyBatis框架⽣成的UserMapper接⼝的实现类
UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User condition = new User();
condition.setId(1); condition.setUsername("lucy");
User user = userMapper.findByCondition(condition);

控制台打印的sql语句如下:

当查询条件只有id存在时,测试代码片段如下:

//获得MyBatis框架⽣成的UserMapper接⼝的实现类
UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User condition = new User();
condition.setId(1);
User user = userMapper.findByCondition(condition);

控制台打印的sql语句如下:

动态 SQL

循环执⾏sql的拼接操作,例如:SELECT * FROM USER WHERE id IN  (1,2,5)。

<select id="findByIds" parameterType="list" resultType="user">
select * from User   <where>     <foreach collection="list" open="id in(" close=")" item="id" separator=",">       #{id}     </foreach>   </where> </select>

测试代码⽚段如下:

//获得MyBatis框架⽣成的UserMapper接⼝的实现类
UserMapper userMapper = sqlSession.getMapper(UserMapper.class); int[] ids = new int[]{2,5};
List<User> userList = userMapper.findByIds(ids); System.out.println(userList);

控制台打印如下:

foreach标签的属性含义如下:

标签⽤于遍历集合,它的属性:

•collection:代表要遍历的集合元素,注意编写时不要写#{}

•open:代表语句的开始部分

•close:代表结束部分

•item:代表遍历集合的每个元素,⽣成的变量名

•sperator:代表分隔符

SQL⽚段抽取

Sql 中可将重复的 sql 提取出来,使⽤时⽤ include 引⽤即可,最终达到 sql 重⽤的⽬的

<!--抽取sql⽚段简化编写-->
<sql id="selectUser" select * from User</sql>
<select id="findById" parameterType="int" resultType="user">
<include refid="selectUser"></include> where id=#{id}
</select>
<select id="findByIds" parameterType="list" resultType="user">
<include refid="selectUser"></include>
<where>
<foreach collection="array" open="id in(" close=")" item="id" separator=",">
#{id}
</foreach>
</where>
</select>

 

标签:数据源,UserMapper,id,mybatis,User,sql,Mybatis,第四,condition
From: https://www.cnblogs.com/eagle888/p/16907333.html

相关文章

  • 初学linux笔记 第四章 windows中开发的QT程序适配linux的修改——error: ‘QT_WARNING
    QT程序本身在windows中进行开发的,移植到linux系统上进行编译后发现了不少问题,需要一一进行修改1.系统时间修改首先是系统时间问题SYSTEMTIMEcurrent_date_time;GetLo......
  • Mybatis出现Caused by: net.sf.jsqlparser.parser.ParseException: ....异常
    今天在开发项目中遇到了一个奇怪的异常,记录一下把!异常信息如下(截取了主要的部分)Causedby:net.sf.jsqlparser.parser.ParseException:Encountered""TOP""top""at......
  • mybatis学习第⼆部分:Mybatis相关概念
    2.1 对象/关系数据库映射(ORM)ORM全称Object/Relation Mapping:表示对象-关系映射的缩写ORM完成⾯向对象的编程语⾔到关系数据库的映射。当ORM框架完成映射后,程序员既可......
  • mybatis学习第三部分:Mybatis基本应⽤
    3.1 快速⼊⻔MyBatis官⽹地址:http://www.mybatis.org/mybatis-3/ 3.1.1 开发步骤:①添加MyBatis的坐标②创建user数据表③编写User实体类④编写映射⽂件UserMappe......
  • mybatis 之 sql语句写法集锦
    1、mapper接口中的方法存在批量数据操作,接口参数是List类型   在mybatis的xml文件中,使用foreach动态标签拼接SQL语句,每一条数据的更新语句对应一条update语句,......
  • 小知识点-第四讲
    装饰模式:它拥有一个设计非常巧妙的结构,他可以动态添加对象功能,通过委托机制复用组件功能在运行时将这些功能组件进行叠加,从而成为一个“超级对象”,使之拥有所有的这些组件......
  • mybatis源码解析1
    一、mybatis的简单使用根据mybatis官网提供的例子,需要这么几个步骤1、获取mybatis配置文件的输入流对象2、创建SqlSessionFactoryBuilder对象3、调用SqlSessionFactor......
  • MyBatisPlus 多数据源动态切换
    一、官方文档https://baomidou.com/pages/a61e1b/#%E6%96%87%E6%A1%A3-documentation二、操作步骤1、引入依赖版本号在下面 懒得单独复制了 一起贴出来了<!......
  • MyBatis练习(初)
    目录环境准备库,表idea准备题目一、简单查询环境准备MySQL,JDK17,Maven,MyBatis库,表库:CREATEDATABASEStuDB;学生表:Student(Sno,Sname,Ssex,Sage,Sdept)其中Sno为......
  • Mybatis中的${}和#{}区别(转载)
    动态sql是mybatis的主要特性之一,在mapper中定义的参数传到xml中之后,在查询之前,mybatis会对其进行动态解析。mybatis为我们提供了两种支持动态sql的语法:#{}以及......