java—MyBatis框架

简介

什么是 MyBatis?
MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

以上内容摘自于MyBatis中文官网:MyBatis中文官网

历史

mybatis原本是apache的一个开源项目ibatis, 2010迁移至谷歌, 改名为 Mybatis, 版本升级为3.0

特点

①Mybatis 是一款优秀的持久层框架
②Mybatis 对 jdbc 进行封装, 简化了操作
③Mybatis 使用 xml 或注解方式, 将数据库记录映射到 java 对象中,
④是一种 orm(Object Relational Mapping 对象关系映射) 实现
⑤它支持动态 SQL 以及数据缓存

搭建

        1.先在数据库创建一张表,在创建一个 maven 项目,创建一个实体类(应该于数据库中的表对应)
        2.导入 MyBatis 和 mysql 的 jar 包,创建 MyBatis 核心配置文件

其中步骤 2 为使用MyBatis框架所要用到的操作

mysql相关操作

-- 创建数据库 ssmdb
CREATE DATABASE ssmdb CHARSET utf8

-- 创建表
-- 管理员表
CREATE TABLE admin(
	id INT PRIMARY KEY AUTO_INCREMENT,
	account VARCHAR(12) UNIQUE NOT NULL,
	`password` VARCHAR(32) NOT NULL,
	`name` VARCHAR(20) NOT NULL,
	gender CHAR(1)
)

-- 添加测试用例
INSERT INTO admin (account, `password`, `name`, gender)
VALUES
('000000', '000000', 'JSON', '男'),
('000001', '000000', '张三', '男')

-- 查询 admin 表中所有数据
SELECT * FROM admin

项目选择

创建Admin类

package com.flash.mybatis.model;

/**
 * @author flash
 * @date 2024/06/01 14:34
 * 功能描述:Admin类
 */
public class Admin {
    private int id;
    private String name;
    private String account;
    private String password;
    private char gender;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAccount() {
        return account;
    }

    public void setAccount(String account) {
        this.account = account;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public char getGender() {
        return gender;
    }

    public void setGender(char gender) {
        this.gender = gender;
    }

    @Override
    public String toString() {
        return "Admin{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", account='" + account + '\'' +
                ", password='" + password + '\'' +
                ", gender=" + gender +
                '}';
    }
}

其中get, set方法不可缺, 底层会使用到

导入 MyBatis 和 mysql 的jar包

所需依赖,在 pom.xml 文件中完成配置即可

<dependencies>
    <!-- MyBtais -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.4.2</version>
    </dependency>

    <!-- mysql -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.16</version>
    </dependency>
</dependencies>

创建 MyBatis 核心配置文件

在resources目录中创建一个xml配置文件,如图所示

该配置文件编写内容

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <settings>
        <!-- 打印日志,添加此设置,会在运行时打印出此次操作的日志 -->
        <setting name="logImpl" value="STDOUT_LOGGING"/>
    </settings>

    <typeAliases>
        <!-- 指定到某一个目录下,如果没有此配置,需要在配置sql管理文件时,填入完整的类地址,
如:com.flash.mybatis.model.Admin -->
        <package name="com.flash.mybatis.model"/>
    </typeAliases>

    <environments default="development">
        <environment id="development">
            <!-- 事物管理方式:就是一次对数据库操作过程中, 执行多条sql的管理
                    转账:
                        从A账户向B账户转钱
                        A-500
                        代码, 异常
                        B+500
                        把所有的操作都成功执行后, 再提交事务, 让数据库最终执行本次提交的所有sql
            -->
            <transactionManager type="JDBC"/><!-- 使用jdbc事务管理 -->
            <!-- 数据库链接池配置
                    频繁的创建与校徽数据库的连接对象比较浪费时间,
                    可以在池子中默认创建若干个连接对象, 有请求使用时, 直接从连接池中取出一个对象,
                    用完还回去但不销毁, 减少了创建和销毁的时间开销
                    如果连接个数不够用时仍然需要创建连接对象,数据库连接池中有一个下限和一个上线,默认最多为10,最少为5个
             -->
            <dataSource type="POOLED">
                <!-- 数据库链接 -->
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/ssmdb?serverTimezone=Asia/Shanghai"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>

    <!-- 配置SQL管理文件 -->
    <mappers>
        <mapper resource="mappers/AdminMapper.xml"/>
    </mappers>
</configuration>

创建与数据库交互所需的接口

package com.flash.mybatis.dao;

import com.flash.mybatis.model.Admin;

import java.util.List;

// 定义功能
public interface AdminDao {
    /*
        根据id查询管理员对象
     */
    Admin findAdminById(int id);

    List<Admin> findAdmins();

    int addAdmin(Admin admin);
}

创建xml文件管理sql

如图所示


该文件内容如下

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.jorg//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.flash.mybatis.dao.AdminDao">
    <insert id="addAdmin" parameterType="Admin">
        INSERT INTO admin (account, `password`, `name`, gender)
        VALUE
        (#{account}, #{password}, #{name}, #{gender})
    </insert>

    <!--
        id必须与方法名一致
        parameterType 接口中定义的方法所需要的参数类型
        resultType    查询结果返回类型
        #{account}    相当于调用 Admin 对象的 account 变量
     -->

    <select id="findAdminById" parameterType="int" resultType="Admin">
        select * from admin where id = #{id}
    </select>

    <select id="findAdmins" resultType="Admin">
        select * from admin
    </select>
</mapper>

测试类

package com.flash.mybatis.test;

import com.flash.mybatis.dao.AdminDao;
import com.flash.mybatis.model.Admin;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.Reader;
import java.util.List;

/**
 * @author flash
 * @date 2024/06/01 17:35
 * 功能描述:测试类
 */
public class Test {
    public static void main(String[] args) throws IOException {
        // 读入 mybatis 核心配置文件
        Reader reader = Resources.getResourceAsReader("mybatis.xml");

        // 创建 SqlSessionFactory 对象
        // sqlSessionFactory 是用来创建 sqlSession的, 由于 sqlSessionFactory 对象创建的开销较大,
        // 所以一个项目只创建一个 sqlSessionFactory 对象, 不用关闭
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);

        // 创建SqlSession对象
        // sqlSession 对象与数据库交互的, 每次与数据库交互, 都需要一个新的连接对象
        // 用完关闭即可
        SqlSession sqlSession = sqlSessionFactory.openSession();

        // 为接口创建一个代理对象
        // 由代理对象调用接口中对应的方法
        AdminDao adminDao = sqlSession.getMapper(AdminDao.class);
        Admin admin = adminDao.findAdminById(1);
        System.out.println(admin);

        List<Admin> admins = adminDao.findAdmins();
        for (Admin admin1 : admins) {
            System.out.println(admin1);
        }

        admin = new Admin();
        admin.setAccount("000002");
        admin.setPassword("000000");
        admin.setName("李四");
        admin.setGender('女');
        System.out.println("count = " + adminDao.addAdmin(admin));

        sqlSession.commit();// 提交数据库事物, 事物只针对 增删改, 查询不需要提交事务
        // 关闭与数据库的会话对象
        sqlSession.close();
    }
}

sqlSession.commit();特别说明

        如果对数据库进行查询操作,那么对数据库不会产生任何影响。如果是增删改操作,会对数据库中的数据进行一定改动。

        试想一种场景:A 给 B 转账 200 元,我们需要对数据库执行两部操作,A 中减去 200,B中增加 200,如果 两步中如有一步发生错误那么都会产生数据错误。解决方法,A 给 B 转账 200 元作为事件,java代码执行无误,将整个事件提交再来完成转账的操作,如果某一步发生错误将不会执行对应的sql语句。

        总结:由于查询操作不会对数据库数据产生影响,直接查询即可,不需要提交;如果是增删改操作,则需要将事务提交后参会执行对应的sql语句

简化测试

上面提到有些对象之需要创建一次, 那么我们就可以把他装入到一个工具类中来让我们每一次使用时直接调用即可, 但是由于要创建一个对象, 所以将他设置为静态对象, 并在static静态代码块中完成初始化, 见代码:

工具类:

package com.flash.mybatis.util;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.Reader;

/**
 * @author flash
 * @date 2024/06/01 17:32
 * 功能描述:
 */
public class MybatisUtil {
    private static Reader reader;
    public static SqlSessionFactory sqlSessionFactory;

    static {
        // 读入 mybatis 核心配置文件
        try {
            reader = Resources.getResourceAsReader("mybatis.xml");
        } catch (IOException e) {
            e.printStackTrace();
        }

        // 创建 SqlSessionFactory 对象
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
    }
}

测试类:

package com.flash.mybatis.test;

import com.flash.mybatis.dao.AdminDao;
import com.flash.mybatis.model.Admin;
import com.flash.mybatis.util.MybatisUtil;
import org.apache.ibatis.session.SqlSession;

import java.io.IOException;
import java.util.List;

/**
 * @author flash
 * @date 2024/06/01 15:23
 * 功能描述:将一些重复的代码封装后使用的案例
 */
public class Test2 {
    public static void main(String[] args) throws IOException {
        SqlSession sqlSession = MybatisUtil.sqlSessionFactory.openSession();

        // 为接口创建一个代理对象
        // 由代理对象调用接口中对应的方法
        AdminDao adminDao = sqlSession.getMapper(AdminDao.class);
        Admin admin = adminDao.findAdminById(1);
        System.out.println(admin);

        List<Admin> admins = adminDao.findAdmins();
        for (Admin admin1 : admins) {
            System.out.println(admin1);
        }

        admin = new Admin();
        admin.setAccount("000002");
        admin.setPassword("000000");
        admin.setName("李四");
        admin.setGender('女');
        adminDao.addAdmin(admin);

        sqlSession.commit();// 提交数据库事物, 事物只针对 增删改, 查询不需要提交事务
        // 关闭与数据库的会话对象
        sqlSession.close();
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/671080.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SparkSql近期使用经验分享

背景 近期在公司使用了SparkSql重构一个由Java开发的ETL程序&#xff0c;因为Java模块不易于修改和部署&#xff0c;而由于SparkSql脚本是由Python开发&#xff0c;便于根据业务需求来开发维护&#xff0c;特别是不需要编译、打包部署。 技术理念 SparkSql是以Sql的形式去开…

三十三篇: 解锁决策之门:专家系统深度探索与未来展望

解锁决策之门&#xff1a;专家系统深度探索与未来展望 在今天这个日益复杂的世界中&#xff0c;我们对决策的速度和质量提出了更高的要求。在众多解决方案中&#xff0c;专家系统作为人工智能的一大分支&#xff0c;扮演着不可或缺的角色。它不仅是技术创新的产物&#xff0c;…

html+CSS+js部分基础运用11

一、改变新闻网页中的字号 1、设计如图1-1所示的界面&#xff0c;要求当网络访问者选择字号中的【大、中、小】时能实现页面字号大小变化&#xff0c;选择“中”时&#xff0c;页面效果如图1所示。 图1 单击前初始状态页面 图2 单击“中”链接后页面 2、div中内容如下&#x…

操作系统|进程和线程的上下文以及他们的上下文切换具体流程?

进程和线程已经是老生常谈的问题了&#xff0c;现在那么他们是如何进行切换的呢&#xff1f;他们之间的切换有什么区别呢&#xff1f;如果你不懂的话&#xff0c;就让我们一起来探讨一下吧&#xff01; 进程上下文切换(context switch) 进程到底由哪些部分组成&#xff1f; …

thingsboard物联网平台快速入门教程

第一步&#xff0c;搭建服务器 使用我已经建好的服务器&#xff0c;thingsboard测试账号,租户管理员账号&#xff0c;物联网测试平台-CSDN博客 第二步&#xff0c;创建一个设备&#xff0c;获取设备Token 用租户管理员账户登录&#xff0c;左侧找到实体->设备&#xff0c…

无法拒绝!GPT-4o 完美适配安卓手机,畅享丝滑体验

无法拒绝&#xff01;GPT-4o 完美适配安卓手机&#xff0c;畅享丝滑体验 前言 人工智能的飞速发展&#xff0c;给我们的生活带来了前所未有的便利。作为AI技术的代表之一&#xff0c;GPT凭借其强大的自然语言处理能力&#xff0c;已经成为许多用户日常生活和工作中的得力助手…

模拟集成电路(6)----单级放大器(共源共栅级 Cascode Stage)

模拟集成电路(6)----单级放大器&#xff08;共源共栅级 Cascode Stage&#xff09; 大信号分析 对M1 V x ≥ V i n − V T H 1 V x V B − V G S 2 V B ≥ V i n − V T H 1 V G S 2 V_{x}\geq V_{in}-V_{TH1}\quad V_{x}V_{B}-V_{GS2}\\V_{B}\geq V_{in}-V_{TH1}V_{GS2} Vx…

Mybatis项目创建 + 规范

文章目录 一、相关概念Mybatis1.1 什么是Mybatis1.1 如何实现简化JDBC 二、如何创建 Mybatis 项目2.1 创建SpringBoot项目 加载依赖2.2 准备数据库 以及 对象的映射2.3 配置数据库连接池2.4 使用Mybatis操作数据库2.5 单元测试 三、其他3.1 数据库与Java对象的映射规则 ---- 结…

【MySQL】Linux安装MySQL

一、center OS环境准备 为了在Linux系统中查看MySQL5.8与8.0版本的区别 我们要准备两个虚拟机&#xff0c;需要的软件&#xff1a;VMware和CentOS7 因为博主之前在学习redis的时候已经安装过一个虚拟机了&#xff0c;所以我就直接克隆了一个CentOS2.0 修改mac地址&#xff0…

基于C#使用ACCESS数据库时遇到的问题记录

一、32位版本Office与64位AccessDatabaseEngine共存安装方法 1. 使用winrar、7zip等软件将AccessDatabaseEngine_X64.exe解压缩&#xff0c;得到AceRedist.msi和files14.cat2个文件 2. 下载Orca MSI编辑修改工具。安装后&#xff0c;使用Orca打开AceRedist.msi&#xff0c;找到…

在iPhone上恢复已删除的Safari历史记录的最佳方法

您是否正在寻找恢复 iPhone 上已删除的 Safari 历史记录的最佳方法&#xff1f;好吧&#xff0c;这篇文章提供了 4 种在有/无备份的情况下恢复 iPhone 上已删除的 Safari 历史记录的最佳方法。现在按照分步指南进行操作。 iPhone 上的 Safari 历史记录会被永久删除吗&#xff1…

爱德蒙得洛希尔:深耕亚洲市场,开启中国投资新篇章!

爱德蒙得洛希尔资产管理&#xff08;法国&#xff09;有限公司&#xff08;以下简称“爱德蒙得洛希尔”&#xff09;是一家具有悠久历史和全球业务网络的金融企业&#xff0c;由洛希尔家族于1953年在法国巴黎创立。作为一家主要从事私人银行和资产管理业务的金融集团&#xff0…

Mybatis编写SQL

文章目录 一、用注解编写1.1 增普通增加获取自增ID 1.2 删和改1.3 查单表查询多表查询 二、用xml编写2.1 使用xml的流程2.2 增普通增加获取自增ID 2.3 删 和 改2.4 查 三、#{} 和 ${}3.1 #{} 、${}3.1 预编译 SQL 、即时编译SQL 两种写法是可以同时存在的 一、用注解编写 1.1 …

【已解决】HtmlWebpackPlugin.getHooks is not a function

安装下面的依赖&#xff0c;获得 html-webpack-plugin 的 beta 版本 npm i html-webpack-pluginnext --save此问题在github上有讨论&#xff1a;https://github.com/facebook/create-react-app/issues/5465

网络报文协议头学习

vxlan&#xff1a;就是通过Vxlan_header头在原始报文前面套了一层UDPIP&#xff08;4/6&#xff09;Eth_hdr 需求背景&#xff1a;VXLAN&#xff1a;简述VXLAN的概念&#xff0c;网络模型及报文格式_vxlan报文格式-CSDN博客 如果服务器作为VTEP&#xff0c;那从服务器发送到接…

Java对象的揭秘

前言 作为一个 Java 程序员&#xff0c;我们在开发中最多的操作要属创建对象了。那么你了解对象多少&#xff1f;它是如何创建&#xff1f;如何存储布局以及如何使用的&#xff1f;本文将对 Java 对象进行揭秘&#xff0c;以及讲解如何使用 JOL 查看对象内存使用情况。 本文是基…

云计算如何助力金融科技企业实现高效运营

一、引言 随着信息技术的飞速发展,云计算作为一种新兴的计算模式,正在逐渐改变着传统金融行业的运营模式。金融科技企业作为金融行业的重要组成部分,面临着日益增长的业务需求和技术挑战。在这一背景下,云计算凭借其弹性扩展、高可用性、低成本等优势,成为金融科技企业实…

VisualSVN Server/TortoiseSVN更改端口号

文章目录 概述VisualSVN Server端更改端口号TortoiseSVN客户端更改远程仓库地址 概述 Subversion&#xff08;SVN&#xff09;是常用的版本管理系统之一。部署在服务器上的SVN Server端通常会在端口号80&#xff0c;或者端口号443上提供服务。其中80是HTTP访问方式的默认端口。…

SSM牙科诊所管理系统-计算机毕业设计源码98077

目 录 摘要 1 绪论 1.1研究目的与意义 1.2国内外研究现状 1.3ssm框架介绍 1.4论文结构与章节安排 2 牙科诊所管理系统系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能…

制作ChatPDF之后端Node搭建(三)

后端Node搭建 接上篇:制作ChatPDF之前端Vue搭建&#xff08;二&#xff09; 项目结构 下面是项目的结构图&#xff0c;包括前端 (Vue.js) 和后端 (Node.js) 的项目结构。 pdf-query-app/ ├── frontend/ │ ├── public/ │ │ ├── index.html │ ├── sr…