mybatis之配置优化and映射器~

简介: mybatis之配置优化and映射器~

环境配置:

mybatis可以配置成适应多种环境,但是要记住,尽管可以配置多个环境,但每个SqlSessionFactory实例只能选择一种环境。


虽然,MyBatis 中有两种类型的事务管理器:type=("[JDBC|MANAGED]")

但是mybatis默认的事务管理器就是JDBC,连接池:POOLED


属性:

我们可以通过properties属性来实现引用配置文件,这些属性都是可外部配置且可动态替换的,既可以在典型的java属性文件中配置,也可以通过properties元素的子元素来传递[db.properties]

引入外部配置文件:

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=false&useUnicode=true&characterEncoding=UTF-8
user=root
password=xxx

在xml文件中,所有的标签都规定了其顺序,当我们把上述的properties标签,放在错误的位置时,就会报错:

mybatis-config.xml文件:

引入外部的配置文件:

注意!注意!


如果出现了下述这种错误,一定要去检查你的外部配置文件中的属性名和mybatis-config.xml配置中的属性名是否一致,比如我,一个写的user,一个写的username,找了好大一会呜呜呜呜

Access denied for user ‘root’@‘localhost’(using password:YES)

如果外部配置文件与核心配置文件包含同一个字段,那么会优先使用外部配置文件

报错如下:

当内置配置文件的密码正确,而引入外部配置文件的密码,错误时:

当内置配置文件的密码错误,而引入外部配置文件的密码,正确时:

查询成功:

别名优化:

方式1:

当实体类涉及很长时,我们可以通过typeAliases标签给它取别名:

<typeAliases>
    <typeAlias type="com.pojo.user" alias="MyUser"/>
</typeAliases>

那么在其他地方需要使用该实体时,我们就能直接使用别名啦。


方式2:


也可以指定一个包名,mybatis会在包名下面搜索需要的java bean,比如:

扫描实体类的包,它的默认别名就为这个类的类名,首字母小写


举例:

在mybatis-config.xml文件中指定包名:

studentsMapper.xml文件中:

在实体类比较少的时候,使用第一种方式,如果实体类比较多,建议使用第二种。第一种可以自定义别名,第二种则不行,如果使用第二种方式想要自定义别名,那么要在指定包的基础上再加注解,此后该类就可通过注解来辨识

如下所示:

映射器:

MapperRegistry:注册绑定我们的Mapper文件

方式1:

<!--每一个Mapper.xml都需要在mybatis核心配置文件中注册!-->
<!--resources的值为映射文件对应的路径 -->
<mappers>
  <mapper resource="dao/students_interface.xml>
</mappers>

方式2:使用class文件绑定注册

<!-- class的值为对应mapper接口的全类名-->
<mappers>
  <mapper class="dao.students_interface/>
</mappers>

方式3:使用扫描包进行注入绑定

<mappers>
  <package name="dao"/>
</mappers>

举例:

注意:

接口和它的Mapper配置文件必须同名,接口和它的Mapper配置文件必须在同一个包下

相关文章
|
3月前
|
XML Java 数据库连接
MyBatis的常见配置
MyBatis 常见配置包括数据库连接、类型别名、映射器等核心模块,合理配置可提升开发效率与系统性能。主要内容涵盖核心配置文件结构、关键配置项详解及配置优先级说明。
383 4
|
3月前
|
SQL Java 数据库连接
MyBatis 的映射关系
MyBatis 核心功能之一是映射关系,支持一对一、一对多和多对多三种 ORM 映射。通过实体类与配置文件结合,开发者可灵活实现数据关联,提升数据库操作效率。
280 4
|
4月前
|
SQL XML Java
通过MyBatis的XML配置实现灵活的动态SQL查询
总结而言,通过MyBatis的XML配置实现灵活的动态SQL查询,可以让开发者以声明式的方式构建SQL语句,既保证了SQL操作的灵活性,又简化了代码的复杂度。这种方式可以显著提高数据库操作的效率和代码的可维护性。
316 18
|
9月前
|
Oracle 关系型数据库 Java
【YashanDB知识库】Mybatis-Plus适配崖山配置
【YashanDB知识库】Mybatis-Plus适配崖山配置
|
9月前
|
Java 数据库连接 微服务
微服务——MyBatis配置——事务管理
本段内容主要介绍了事务管理的两种类型:JDBC 和 MANAGED。JDBC 类型直接利用数据源连接管理事务,依赖提交和回滚机制;而 MANAGED 类型则由容器全程管理事务生命周期,例如 JEE 应用服务器上下文,默认会关闭连接,但可根据需要设置 `closeConnection` 属性为 false 阻止关闭行为。此外,提到在使用 Spring + MyBatis 时,无需额外配置事务管理器,因为 Spring 模块自带的功能可覆盖上述配置,且这两种事务管理器类型均无需设置属性。
162 0
|
9月前
|
Java 数据库连接 数据库
微服务——MyBatis配置——多环境配置
在 MyBatis 中,多环境配置允许为不同数据库创建多个 SqlSessionFactory。通过传递环境参数给 SqlSessionFactoryBuilder,可指定使用哪种环境;若忽略,则加载默认环境。`environments` 元素定义环境配置,包括默认环境 ID、事务管理器和数据源类型等。每个环境需唯一标识,确保默认环境匹配其中之一。代码示例展示了如何构建工厂及配置 XML 结构。
164 0
|
9月前
|
缓存 Java 数据库连接
微服务——MyBatis配置——常见配置
本文介绍了 MyBatis 的常见配置及其加载顺序。属性配置优先级为:方法参数传递的属性 &gt; resource/url 属性中配置 &gt; properties 元素中指定属性。同时列举了多个关键配置项,如 `cacheEnabled`(全局缓存开关)、`lazyLoadingEnabled`(延迟加载)、`useGeneratedKeys`(使用 JDBC 自动生成主键)等,并详细说明其作用、有效值及默认值。这些配置帮助开发者优化 MyBatis 的性能与行为。
148 0
|
7月前
|
SQL XML Java
菜鸟之路Day35一一Mybatis之XML映射与动态SQL
本文介绍了MyBatis框架中XML映射与动态SQL的使用方法,作者通过实例详细解析了XML映射文件的配置规范,包括namespace、id和resultType的设置。文章还对比了注解与XML映射的优缺点,强调复杂SQL更适合XML方式。在动态SQL部分,重点讲解了`&lt;if&gt;`、`&lt;where&gt;`、`&lt;set&gt;`、`&lt;foreach&gt;`等标签的应用场景,如条件查询、动态更新和批量删除,并通过代码示例展示了其灵活性与实用性。最后,通过`&lt;sql&gt;`和`&lt;include&gt;`实现代码复用,优化维护效率。
677 5
|
9月前
|
Java 数据库连接 数据库
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——MyBatis 介绍和配置
本文介绍了Spring Boot集成MyBatis的方法,重点讲解基于注解的方式。首先简述MyBatis作为持久层框架的特点,接着说明集成时的依赖导入,包括`mybatis-spring-boot-starter`和MySQL连接器。随后详细展示了`properties.yml`配置文件的内容,涵盖数据库连接、驼峰命名规范及Mapper文件路径等关键设置,帮助开发者快速上手Spring Boot与MyBatis的整合开发。
1255 0
|
9月前
|
Java 数据库连接 mybatis
MyBatis篇-映射关系(1-1 1-n n-n)
本文介绍了MyBatis中四种常见关系映射的配置方法,包括一对一、一对多、多对一和多对多。**一对一**通过`resultMap`实现属性与字段的映射;**一对多**以用户-角色为例,使用`&lt;collection&gt;`标签关联集合数据;**多对一**以作者-博客为例,利用`&lt;association&gt;`实现关联;**多对多**则通过引入第三方类(如UserForDept)分别在User和Dept类中添加集合属性,并配置对应的`&lt;collection&gt;`标签完成映射。这些方法解决了复杂数据关系的处理问题,提升了开发效率。