项目总结2——mybatis配置的理解

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:
之前的项目基本上都是用mongodb,以至于mysql相关的知识异常薄弱,这次连续一个半月的加班,总算是实际用到了mysql,也使自己对mysql了解的更多,对mybatis了解的更多,这里就说一说经过这一个项目,我对mybatis配置的进一步理解。

一般来说,一个比较完整的mybatis文件大概如下:
<!--第一部分-->
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<!--第二部分-->
<mapper namespace="com.cmsz.om.dao.automaticInspection.HostCollectionDao">
<!--第三部分-->
    <resultMap id="hostCollection"
        type="com.cmsz.om.model.automaticInspection.HostCollectionModel">
        <id column="id" property="id" jdbcType="INTEGER" />
        <result column="pred_exec_time" property="predExecTime" jdbcType="TIMESTAMP" />
        <result column="exec_time" property="execTime" jdbcType="TIMESTAMP" />
        <result column="host_ip" property="hostIp" jdbcType="VARCHAR" />
        <result column="host_name" property="hostName" jdbcType="VARCHAR" />
        <result column="check_type" property="checkType"
            jdbcType="INTEGER" />
        <result column="excute_time" property="excuteTime"
            jdbcType="FLOAT" />
        <result column="latency" property="latency" jdbcType="FLOAT" />
        <result column="opr_result" property="oprResult" jdbcType="VARCHAR" />
        <result column="tranc_result" property="trancResult"
            jdbcType="VARCHAR" />
        <result column="create_time" property="createTime" jdbcType="TIMESTAMP" />
    </resultMap>
<!--第四部分-->
    <select id="findPer" parameterType="map" resultMap="hostCollection">
    SELECT t.HOST_IP,DATE_FORMAT(t.CREATE_TIME,"%Y-%m-%d %H:00:00") createTime,t.CHECK_TYPE,t.OPR_RESULT 
		 FROM om_test.host_collect_datas t  
		 WHERE  
		 <![CDATA[
		 T.CREATE_TIME>=#{startTime} and T.CREATE_TIME<#{endTime} 
		]]>
		 GROUP BY t.HOST_IP,t.check_type,DATE_FORMAT(t.CREATE_TIME,"%Y-%m-%d %H:00:00")
	</select>
</mapper>

上边我标注了一至四四个部分,正常情况来说,这基本的四部分是必不可少的,下边是我对这四部分的理解:
第一部分是mybatis配置文件必不可少的,也可以说是基本固定的,算是mybatis文件的头部声明,以便于spring扫描时能够知道这是个mybatis文件,从而正常的解析。

第二部分namespace,直接指向我们对应的dao接口的完整路径,包括包名和类名,这个就需要根据不同的dao接口进行适当的改变。

第四部分是我们操作数据库的sql语句,结合mybatis的一些标签使mybatis生成正确的sql语句,这一步分很重要,主要涉及到sql语句和编写和mysql标签的使用。

而我这里要着重说明的是第三部分,因为有比较长的一段时间我并不能真正的理解这个配置具体的含义,以至于实际运用中犯了若干个错误。
在这一部分中又可以分为几个比较小的部分,其中的id,相信了解spring的都应该明白是什么意思以及他的作用,就像我们这里第四部分resultMap="hostCollection"就直接引用了这个id。
接下来的type,这里是直接指向的我们java代码中的实体类,和dao接口一样需要完整的路径,即完整包名和类名。
最重头的其实在下边,也就是我们可以看到的若干个重复的result,以及result里边的column和property以及jdbcType。
很早以前,我知道这里是数据库和实体类的对应,但是并不明白究竟是怎么个对应法,因此有一次我column配的是实体类的属性名,而property配的则是数据库中的字段名。由于当时的名字都起得一模一样,也就导致程序正常运行,我以为这样就是对的。
但是后来在一个新的mybatis配置中,我依然这样的配置,结果由于数据库字段名和实体类的属性名并不一样,就导致程序无法正常运行,最后我一番修改后,把column对应到了数据库中的字段名,把property对应到了实体类的属性名。
然后,因为sql不是太麻烦,不论是查询条件还是返回结构都没有额外的字段,所以这样之后运行程序也再次正常,于是我便以为这样便是对的。
知道最近,又一次的业务需求,使得返回值不仅仅包括数据库表中原有的字段,经过了一番挣扎后,我才终于发现,原来property确实是对应实体类的属性。
但是,column实际上对应的是mybatis中sql语句的返回值,而不是我之前所以为的数据库表中的实际字段。
至此,我觉得自己大概算是真正的理解了mybatis配置的具体含义,只是不知道是不是还有下一次遇到新的问题,然后再像之前一样,继续推翻这个理解。
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
缓存 NoSQL Java
Mybatis学习:Mybatis缓存配置
MyBatis缓存配置包括一级缓存(事务级)、二级缓存(应用级)和三级缓存(如Redis,跨JVM)。一级缓存自动启用,二级缓存需在`mybatis-config.xml`中开启并配置映射文件或注解。集成Redis缓存时,需添加依赖、配置Redis参数并在映射文件中指定缓存类型。适用于查询为主的场景,减少增删改操作,适合单表操作且表间关联较少的业务。
|
4月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
928 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
4月前
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
113 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
5月前
|
SQL XML Java
mybatis复习01,简单配置让mybatis跑起来
文章介绍了MyBatis的基本概念、历史和特点,并详细指导了如何配置MyBatis环境,包括创建Maven项目、添加依赖、编写核心配置文件、创建数据表和实体类、编写Mapper接口和XML配置文件,以及如何编写工具类和测试用例。
mybatis复习01,简单配置让mybatis跑起来
|
5月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
96 1
|
6月前
|
Java 数据库连接 mybatis
成功解决: Invalid bound statement (not found) 在已经使用mybatis的项目里引入mybatis-plus,结果不能共存的解决
这篇文章讨论了在已使用MyBatis的项目中引入MyBatis-Plus后出现的"Invalid bound statement (not found)"错误,并提供了解决方法,主要是通过修改yml配置文件来解决MyBatis和MyBatis-Plus共存时的冲突问题。
成功解决: Invalid bound statement (not found) 在已经使用mybatis的项目里引入mybatis-plus,结果不能共存的解决
|
6月前
|
Java 关系型数据库 MySQL
1、Mybatis-Plus 创建SpringBoot项目
这篇文章是关于如何创建一个SpringBoot项目,包括在`pom.xml`文件中引入依赖、在`application.yml`文件中配置数据库连接,以及加入日志功能的详细步骤和示例代码。
|
6月前
|
druid Java 数据库连接
SpringBoot项目整合MybatisPlus持久层框架+Druid数据库连接池,以及实现增删改查功能
SpringBoot项目整合MybatisPlus和Druid数据库连接池,实现基本的增删改查功能。
482 0
|
6月前
|
安全 Java 数据库连接
后端框架的学习----mybatis框架(3、配置解析)
这篇文章详细介绍了MyBatis框架的核心配置文件解析,包括环境配置、属性配置、类型别名设置、映射器注册以及SqlSessionFactory和SqlSession的生命周期和作用域管理。
后端框架的学习----mybatis框架(3、配置解析)
|
6月前
|
SQL Java 数据库连接
springboot+mybatis+shiro项目中使用shiro实现登录用户的权限验证。权限表、角色表、用户表。从不同的表中收集用户的权限、
这篇文章介绍了在Spring Boot + MyBatis + Shiro项目中,如何使用Shiro框架实现登录用户的权限验证,包括用户、角色和权限表的设计,以及通过多个表查询来收集和验证用户权限的方法和代码实现。
springboot+mybatis+shiro项目中使用shiro实现登录用户的权限验证。权限表、角色表、用户表。从不同的表中收集用户的权限、