myBatis配置解析

文档:https://mybatis.net.cn/configuration.html#settings

1配置核心文件

mybatis-config.xml
MyBatis 的配置文件包含了会深深影响MyBatis行为的设置和属性信息。

1 configuration(配置)
2 properties(属性)
3 settings(设置)
4 typeAliases(类型别名)
5 typeHandlers(类型处理器)
6 objectFactory (对象工厂)
7 plugins(插件)
8 environments(环境配置)
9 environment(环境变量)
10 transactionManager(事务管理器)
11 datasource(数据源)
12 database1dProvider(数据库厂商标识)
13 mappers(映射器)

2环境配置(environments)


MyBatis可以配置成适应多种环境
不过要记住:尽管可以配置多个环境,但每个SqlSessionFactory实例只能选择一种环境。学会使用配置多套运行环境!
Mybatis默认的事务管理器就是JDBC(JDBC/Managed),连接池:POOLED(UNPOOL/POOLES/JNDI)

3属性(properties)

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

db.properties

driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useUnicode=ture&useSSL=true&characterEncoding=UTF-8
username=root
password=123456

核心配置文件,xml文件映入

  • 可以映入外部文件
  • 同时也可以配置源
  • 但是有优先顺序:外部文件比内部配置优先
<!--引入外部文件-->
    <properties resource="db.properties">
        <property name="username" value="root"/>
        <property name="password" value="123456"/>
    </properties>

4给类起别名

  • 类型别名是为Java类型设置一个短的名字。
  • 存在的意义仅在于用来减少类完全限定名的冗余。

在myBatis-config.xnl置文件中插入,就可以在sql.xml文件中使用

<!--给类起别名-->
    <typeAliases>
   <typeAlias type="pojo.User" alias="User"/>
    </typeAliases>

也可以在myBatis-config.xnl置文件中配置指定的包,包下的类就可以直接用在sql.xml文件中使用(首字母小写)

<!--给类起别名-->
    <typeAliases>
      <package name="pojo"/>
    </typeAliases>

实体类较少的时候用第一种,多的时候第二种
第一种可以在DIY别名。第二种不行,但是可以实体类上注解起别名

@Alias( "user")
public class user{
  }

5设置

日志实现方式

6映射器

方式一

    <mappers>
        <mapper resource="XXX/XXX/UserDao.xml"/>
    </mappers>

方式二
注意点

  • 接口和他的Mapper配置文件必须同名!
  • 接口和他的Mapper配置文件必须在同一个包下!(UserMapper接口和UserMapper.xml)

    <mappers>
        <mapper class="XX.XX.UserDao"/> 
    </mappers>

方式三
注意点

  • 接口和他的Mapper配置文件必须同名!
  • 接口和他的Mapper配置文件必须在同一个包下!(UserMapper接口和UserMapper.xml)
    <mappers>
        <package name="XX.XX"/>
    </mappers>

7结果集映射

数据库和实体类字段不一致时,会发生查询结果为NULL情况
方法1:sql语句后加别名

select id,name,pwd password from User;

方法二,Usermapper.xml添加结果集映射

<!--结果集映射-->
    <resultMap id="UserMap" type="user">
        <!--column数据库中的字段, property实体类中的属性-->
        <result column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="pwd" property="password"/>
    </resultMap>

    <select id="runSQL" resultMap="UserMap">
        select * from myBatis.user;
    </select>

  • resultMap元素是MyBatis 中最重要最强大的元素
  • ResultMap的设计思想是,对于简单的语句根本不需要配置显式的结果映射,而对于复杂一点的语句只需要描述它们的关系就行了。
  • ResultMap最优秀的地方在于,虽然你已经对它相当了解了,但是根本就不需要显式地用到他们。
  • 如果世界总是这么简单就好了。
posted @   小幼虫虫  阅读(49)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示