首页 > 其他分享 >Mybatis入门

Mybatis入门

时间:2024-06-07 10:55:05浏览次数:24  
标签:Java 入门 映射 MySQL MyBatis SQL Mybatis 配置文件

目录

一、简介

1.1、MyBatis历史

MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下, iBatis3.x正式更名为MyBatis。代码于2013年11月迁移到Github。

iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。 iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)。

1.2、特性

1) MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架

2) MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集

3) MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录

4) MyBatis 是一个半自动的ORM(Object Relation Mapping)框架

1.3、下载

https://github.com/mybatis/mybatis-3

1.4、和其它持久层技术对比

JDBC

  1. SQL 夹杂在Java代码中耦合度高,导致硬编码内伤

  2. 维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见

  3. 代码冗长,开发效率低

Hibernate和JPA

  1. 操作简便,开发效率高

  2. 程序中的长难复杂 SQL 需要绕过框架

  3. 内部自动生产的 SQL,不容易做特殊优化

  4. 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。

  5. 反射操作太多,导致数据库性能下降

Mybatis

  1. 轻量级,性能出色

  2. SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据

  3. 开发效率稍逊于Hibernate,但是完全能够接受

二、搭建Mybatis

2.1开发环境

IDE:idea 2022.2.3

构建工具:maven 3.6.0

MySQL版本:MySQL 5

MyBatis版本:MyBatis 3.5.7

MySQL不同版本的注意事项:

  1. 驱动类driver-class-name

    MySQL 5版本使用jdbc5驱动,驱动类使用:com.mysql.jdbc.Driver

    MySQL 8版本使用jdbc8驱动,驱动类使用:com.mysql.cj.jdbc.Driver

  2. 连接地址url

    MySQL 5版本的url:

    jdbc:mysql://localhost:3306/ssm

    **MySQL 8版本的url: **

    jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC

**否则运行测试用例报告如下错误: **

java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more 

三、创建MyBatis的核心配置文件

习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合Spring

之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。

核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息

核心配置文件存放的位置是src/main/resources目录下

3.1、创建mapper接口

**MyBatis中的mapper接口相当于以前的dao。但是区别在于,mapper仅仅是接口,不需要提供实现类。 **

3.2、创建MyBatis的映射文件

相关概念:ORM(Object Relationship Mapping)对象关系映射。

  1. 对象:Java的实体类对象

  2. 关系:关系型数据库

  3. 映射:二者之间的对应关系

Java****概念 数据库概念
属性 字段/列
对象 记录/行

**映射文件的命名规则: **

表所对应的实体类的类名+Mapper.xml

例如:表user,映射的实体类为User,所对应的映射文件为UserMapper.xml

因此一个映射文件对应一个实体类,对应一张表的操作

MyBatis映射文件用于编写SQL,访问以及操作表中的数据

MyBatis映射文件存放的位置是src/main/resources/mappers目录下

3.3、通过junit测试对应功能

  1. SqlSession:代表Java程序和数据库之间的会话。(HttpSession是Java程序和浏览器之间的会话)

  2. SqlSessionFactory:是“生产”SqlSession的“工厂”。

  3. 工厂模式:如果创建某一个对象,使用的过程基本固定,就可以把创建这个对象的相关代码封装到一个“工厂类”中,以后都使用这个工厂类来“生产”所需要的对象。

3.4、加入log4j日志功能

  1. 引入依赖

    <!-- log4j日志 -->
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
    
  2. 加入log4j的配置文件(log4j的配置文件名为log4j.xml,存放的位置是src/main/resources目录下)

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
    
    <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    
        <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
            <param name="Encoding" value="UTF-8" />
            <layout class="org.apache.log4j.PatternLayout">
                <param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m  (%F:%L) \n" />
            </layout>
        </appender>
        <logger name="java.sql">
            <level value="debug" />
        </logger>
        <logger name="org.apache.ibatis">
            <level value="info" />
        </logger>
        <root>
            <level value="debug" />
            <appender-ref ref="STDOUT" />
        </root>
    </log4j:configuration>
    

**日志的级别 **

**FATAL(致命)>ERROR(错误)>WARN(警告)>INFO(信息)>DEBUG(调试) **

从左到右打印的内容越来越详细

查询:

查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射关系

**resultType:自动映射,用于属性名和表中字段名一致的情况 **

resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况

标签:Java,入门,映射,MySQL,MyBatis,SQL,Mybatis,配置文件
From: https://www.cnblogs.com/ning23/p/18236796

相关文章

  • Three.js入门指南:从基础到实践的三维渲染之旅
    threejs相关资料threejs官网threejs案例安装(Installation)使用NPM和构建工具进行安装对于大多数用户而已,从npm包注册表中心安装并使用构建工具会是一个更推荐的方案。因为项目需要的依赖越多,就越有可能遇到静态托管无法轻易解决的问题。而使用构建工具,导入本地J......
  • ComfyUI 完全入门:必备插件
    ComfyUI 是一个基于StableDiffusion的AI绘画创作工具,最近发展势头特别迅猛,但是ComfyUI的上手门槛有点高,用户需要对StableDiffusion以及各种数字技术的原理有一定的了解才行。这个系列将会介绍ComfyUI的一些基础概念和使用方法,让大家更快的掌握ComfyUI的使用技巧,创......
  • .NET之Hangfire快速入门和使用
    原文地址:.NET之Hangfire快速入门和使用-追逐时光者-博客园(cnblogs.com)前言:定时任务调度问题,是一个老生常谈的问题。网上有许多定时任务调度的解决方案,对于我而言很早以前主要是使用Window计划和Window服务来做任务定时执行,然后就开始使用定时任务调度框架Quartz.N......
  • MyBatis-Plus多表联查
    一、引依赖注意:mybatisplusversion>=3.4.0<dependency><groupId>com.github.yulichang</groupId><artifactId>mybatis-plus-join</artifactId><version>1.2.4</version></dependency> 二、使用方法mapper......
  • 【C语言从入门到入土】第三章流程控制
    第三章流程控制正式开始对流程控制语句的学习不是你的能力,决定了你的命运,而是你的决定,改变了你的命运。想,都是问题,做,才是答案。站着不动,永远是观众,想到做到,才是王道控制类语句帮助理解1.if()…else…条件语句,层层递进的if(条件){表达式01}else{表......
  • 5分钟入门大模型,就5分钟
    这个是大模型系列课程的第一节。接下来我带着大家一起拥抱新技术,分享的进展不会很快,大概一周一次,有空可以直播讲解或实操。为了照顾那些工程出身,甚至非技术同学,我这个系列会从小白开始,从基础概念入门逐步展开。我不会研究基础大模型,而是会关注应用层,当然也会涉及预训练、知识......
  • 图神经网络GNN实践入门
    参考视频网址:https://www.bilibili.com/video/BV1MP41187pv/?spm_id_from=333.999.0.0&vd_source=590f4019caa7ed7b4e57c0e869ad0867文章目录图神经网络GNN一、GNN的优势1、处理非欧几里得数据2、捕捉节点间的复杂关系3、信息聚合和传递4、适用于各种图相关任务二、G......
  • ChatGPT Prompt技术全攻略-入门篇:AI提示工程基础
    系列篇章......
  • 【入门教程】5分钟教你快速学会集成Java springboot ~
    介绍ApacheDolphinScheduler是一个分布式易扩展的开源分布式调度系统,支持海量数据处理,具有任务流程调度、任务流程编排、任务监控告警、工作流引擎等功能。本文将介绍如何将ApacheDolphinScheduler集成到JavaSpringboot项目中,以实现更灵活和便捷的调度功能。步骤步骤一:添......
  • Netty 快速入门
    什么是NettyNetty的官网:[https://netty.io/Netty是一个JavaNIO技术的开源异步事件驱动的网络编程框架,用于快速开发可维护的高性能协议服务器和客户端。往通俗了讲,可以将Netty理解为:一个将JavaNIO进行了大量封装,并大大降低JavaNIO使用难度和上手门槛的网络编程框架。Net......