首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Mybatis-03 配置解析

Mybatis-03 配置解析

作者头像
张小驰出没
发布2021-04-15 17:04:41
发布2021-04-15 17:04:41
59500
代码可运行
举报
运行总次数:0
代码可运行

Mybatis-03 配置解析

Mybatis系列文章已经完成上传: 一、什么是Mybatis 二、CRUD 三、配置解析 四、日志、分页 五、注解开发 六、动态Sql

配置解析

1、核心配置文件

mybatis-config.xml

configuration(配置) properties(属性) settings(设置) typeAliases(类型别名) typeHandlers(类型处理器) objectFactory(对象工厂) plugins(插件) environments(环境配置) environment(环境变量) transactionManager(事务管理器) dataSource(数据源) databaseIdProvider(数据库厂商标识) mappers(映射器)

2、环境配置

MyBatis 可以配置成适应多种环境

不过要记住:

尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。学会使用配置多套运行环境!

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

3、属性

我们可以通过properties属性来实现引用配置文件

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

3.1 编写一个配置文件

创建一个db.properties文件:

代码语言:javascript
代码运行次数:0
运行
复制
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8
jdbc.username=root           #数据库账号
jdbc.password=root           #数据库密码
3.2 在配置文件引入
代码语言:javascript
代码运行次数:0
运行
复制
  <properties resource="db.properties">
    properties>
    
    <environments default="development">
        <environment id="development">
            
            <transactionManager type="JDBC" />
            
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}" />
                <property name="url" value="${jdbc.url}" />
                <property name="username" value="${jdbc.username}" />
                <property name="password" value="${jdbc.password}" />
            dataSource>
        environment>
    environments>

可以直接引入外部文件 ,可以在其中增加一些属性配置

如果两个文件有同一字段,优先使用外部配置文件的!

类型别名

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

1.类别名

当通过设置MyBatis配置文件 中的 typeAliases 属性后,就可以为 sql 映射文件中的输入 / 输出参数设置类型别名,然后在sql 映射配置文件中使用该别名。

配置文件:

代码语言:javascript
代码运行次数:0
运行
复制
<typeAliases>
     <typeAlias type="pojo.user" alias="user"/>
typeAliases>

sql 映射配置文件,示例代码如下:

代码语言:javascript
代码运行次数:0
运行
复制
<select id="getUserList" resultType="user" >
      select * from mybatis.user
select>

2.别名拓展

创建的包里可能也会存在其他多个 JavaBean对象类,这时候一个一个配置别名很麻烦,就需要批量定义别名,批量指定很简单,只要指定包名即可,其定义别名的规范就是对应包的类名首字母变为小写

配置文件:

代码语言:javascript
代码运行次数:0
运行
复制
<typeAliases>
    <package name="pojo"/>   
typeAliases>

这时设置的包下的类就都有了别名,别名就是类名(首字母小写)。

3.注解配置别名

通过注解的方式来配置别名,在需要配置别名的类前通过 @Alias 注解即可,参数就是别名名称

示例代码:

代码语言:javascript
代码运行次数:0
运行
复制
@Alias("user")
public class user{
    //其他代码
}

映射器

1.相对类路径进行映射

代码语言:javascript
代码运行次数:0
运行
复制
<mappers >
    <mapper resource="xxx/xxx/xxxxMapper.xml"/>
mappers>

2使用映射器接口实现类的完全限定类名

代码语言:javascript
代码运行次数:0
运行
复制
<mappers >
    <mapper class="xxx.xxxx.xxx.xxxxMapper"/>
mappers>

注意:接口和它的Mapper文件必须同名,且在同一个包

3.将包内的映射器接口实现全部注册为映射器

代码语言:javascript
代码运行次数:0
运行
复制
<mappers >
    <package name="xxx.xxx.dao"/>
mappers>

注意:接口和它的Mapper文件必须同名,且在同一个包

解决属性名和字段名不一致的问题

数据库:

实体类:

可以从上图看出,数据库中的pwd和实体类中的password不同,会导致以下结果:

解决方法

1.起别名

起别名,在字段名后用as对应属性名,pwd as password

代码语言:javascript
代码运行次数:0
运行
复制
<mapper namespace="com.Dao.UserDao">
    <select id="getUserList" resultType="pojo.user" >
        select id,name,pwd as password from mybatis.user
    select>
mapper>
2.使用resultMap
代码语言:javascript
代码运行次数:0
运行
复制
<resultMap id="user" type="pojo.user">
        
        <id column="id" property="id"/>
        <result column="name" property="name" />
        <result column="pwd" property="password" />
resultMap>

<select id="getUserList" resultMap="user" >
        select * from mybatis.user
select>

Test时,会出现bug:

  • 首先是:2 字节的 UTF-8 序列的字节 2 无效
    • 这个问题是因为在xml文件中的中文注释的问题,将xml文件的中文注释删除,解决
    • xml文件顶部的encoding=UTF-8改为encoding=UTF8可以解决问题
  • 第二个是:数据库连接问题
    • 设置setTimeZone=UTC,没有解决
    • 设置set-on-borrow=true,没有解决重启mysql,没有解决
    • 最终发现,mysql版本问题,而Maven导入的依赖包和mysql版本不同
  • resultMap 元素是 MyBatis 中最重要最强大的元素
  • ResultMap 的设计思想是,对于简单的语句根本不需要配置显式的结果映射,而对于复杂一点的语句只需要描述它们的关系就行了。

个人博客为: MoYu’s Github Blog MoYu’s Gitee Blog

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/02/18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Mybatis-03 配置解析
    • 配置解析
      • 1、核心配置文件
      • 2、环境配置
      • 3、属性
    • 类型别名
      • 1.类别名
      • 2.别名拓展
      • 3.注解配置别名
    • 映射器
      • 1.相对类路径进行映射
      • 2使用映射器接口实现类的完全限定类名
      • 3.将包内的映射器接口实现全部注册为映射器
    • 解决属性名和字段名不一致的问题
      • 解决方法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档