Mybatis-入门程序、 数据库连接池、XML映射配置文件、MybatisX

news2025/5/30 13:36:54

一. Mybatis

        1. Mybatis是一款优秀的持久层框架,用于简化jdbc的开发

2. Mybatis本是Apache的一个开源项目iBatis,2010年这个项目有Apache迁移到了Google code,并且改名为MyBatis,2013年11月迁移到Github

3.官网:MyBatis 3 | 简介 – mybatishttps://mybatis.org/mybatis-3/zh_CN/index.html

 二. MyBaits-入门程序

        1. 创建SpringBoot工程,引入MyBatis相关依赖

        2. 准备数据库表emp、实体类user

        3. 配置Mybatis(在application.prooerties中数据库连接信息)

        4. 编写MyBatis程序:编写MyBatis的持久层接口,定义SQL(注解/XML)

package com.wyyzs.mapper;

import com.wyyzs.pojo.Emp;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;

@Mapper //应用程序在运行时,会自动创建这个接口的实现类对象,并把对象注入到spring容器中
public interface EmpMapper {

    /*
    * 查询所有数据
    * */
    @Select("select * from emp")
    public List<Emp> findAll();
}
package com.wyyzs.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.Date;

@Data //getter setter toString
@AllArgsConstructor //全参构造
@NoArgsConstructor //无参构造
public class Emp {
    Integer id;
    String username;
    String password;
    String name;
    Integer gender;
    String phone;
    Integer job;
    Integer salary;
    Date entry_date;
    String image;
    Date create_time;
    Date update_time;

}
package com.wyyzs;

import com.wyyzs.mapper.EmpMapper;
import com.wyyzs.pojo.Emp;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;

@SpringBootTest //SpringBoot单元测试的注解 - 当前测试类当中的测试方法运行时,会启动整个SpringBoot应用 - ioc容器
class JavaMyBatisApplicationTests {

    @Autowired
    private EmpMapper empMapper;

    @Test
    public void testFindAll(){
        List<Emp> emps = empMapper.findAll();
        emps.forEach(System.out::println);
    }
}

注意:测试类所在的包需要与引导类包名相同(或放在引导类所在包的子包下)

三. Mybatis辅助配置-配置SQL提示

四. 辅助配置-配置mybatis的日志输出

        1. 默认情况下,在mybatis中执行SQL语句时,并不能看到SQL语句的执行日志,在

application.properties加入以下配置,即可查看日志

# mybatis的日志输出 (输出到控制台)
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

五. 数据库连接池

        1. 数据库连接池是一个容器,负责分配、管理数据库连接(Connection)

        2.它允许应用程序重复使用一个现有的数据库连接,而不是再建立一个

        3. 释放空闲超过最大空闲时间的连接,来避免因为没有释放连接而引起的数据库连接遗漏

        4. 优势:(1) 资源重用 (2) 提升系统响应速度 (3) 避免数据库连接遗漏

        5. 标准接口:DataSource        

                sun公司提供的数据连接池接口,由第三方组织实现此接口

                功能:获取连接 Connection getConnection() throews SQLException;

        6. Druid(德鲁伊)

                (1)  Druid连接池是阿里巴巴开源数据库连接池项目;

                (2) 功能强大,性能优秀,是Java语言最好的数据库连接池之一;

        7. 切换数据库连接池

六. Mybatis中 #号 与 $ 号

        例如:@Delete("delete from emp where id = #{id}")

                 @Select("select id,name,score from ${tableName} order by ${sortField}") --很少使用

七. Mybatis-增删改查操作

package com.wyyzs.mapper;

import com.wyyzs.pojo.Emp;
import org.apache.ibatis.annotations.*;

import java.util.List;

@Mapper //应用程序在运行时,会自动创建这个接口的实现类对象,并把对象注入到spring容器中
public interface EmpMapper {

    /*
    * 查询所有数据
    * */
    @Select("select * from emp")
    public List<Emp> findAll();

    /*
    * 根据ID删除数据
    * */
    @Delete("delete from emp where id = #{id}")
    public Integer deleteById(Integer id);

    /*
    * 新增数据
    * */
    @Insert("insert into emp(username,password,name,gender,phone,job,salary,entry_date,image,create_time,update_time) " +
            "values(#{username},#{password},#{name},#{gender},#{phone},#{job},#{salary},#{entry_date},#{image},#{create_time},#{update_time})")
    public Integer insert(Emp emp);

    /*
    * 根据ID更新数据
    * */
    @Update("update emp set username=#{username},password=#{password},name=#{name},gender=#{gender},phone=#{phone},job=#{job},salary=#{salary},entry_date=#{entry_date}," +
            "image=#{image},create_time=#{create_time},update_time=#{update_time} where id=#{id}")
    public Integer update(Emp emp);

    /*
    * 根据用户名和密码查询数据
    * @Param 注解:将参数传递给SQL语句 作用是为接口的方法形参起名字的
    *   说明:如果是基于官方骨架创建的springboot项目,接口编译时会保留方法的形参名,@Param注解可以省略(#{形参名})
    *   public Emp findByUsernameAndPassword(String username, String password);
    * */
    @Select("select * from emp where username=#{username} and password=#{password}")
    public Emp findByUsernameAndPassword(@Param("username") String username, @Param("password") String password);


}

package com.wyyzs;

import com.wyyzs.mapper.EmpMapper;
import com.wyyzs.pojo.Emp;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.Date;
import java.util.List;

@SpringBootTest //SpringBoot单元测试的注解 - 当前测试类当中的测试方法运行时,会启动整个SpringBoot应用 - ioc容器
class JavaMyBatisApplicationTests {

    @Autowired
    private EmpMapper empMapper;

    @Test
    public void testFindAll(){
        List<Emp> emps = empMapper.findAll();
        emps.forEach(System.out::println);
    }

    /*
     * 根据ID删除数据 返回影响行数
     * */
    @Test
    public void testDeleteByID(){
       Integer num =  empMapper.deleteById(2);
        System.out.println(num);
    }

    /*
    * 测试新增数据
    * */
    @Test
    public void testInsert(){
        Emp emp = new Emp(null,"laoshu","123456","老鼠",1,"14785209630",1,10000,new Date(),"1.jpg",new Date(),new Date());
        Integer num =  empMapper.insert(emp);
        System.out.println(num);
    }

    /*
    * 测试更新数据
    * */
    @Test
    public void testUpdate(){
        Emp emp;
        emp = new Emp(3,"nvqiang","123456","女枪",1, "13333456789",1,10000,new Date(),"1.jpg",new Date(),new Date());
        Integer num =  empMapper.update(emp);
        System.out.println(num);
    }

    /*
    * 测试根据用户名和密码查询数据
    * */
    @Test
    public void testFindByUsernameAndPassword(){
        Emp emp = empMapper.findByUsernameAndPassword("nvqiang","123456");
        System.out.println(emp);
    }

}

    @Param 注解:将参数传递给SQL语句 作用是为接口的方法形参起名字的

                如果Mapper接口形参中只有一个参数,可以不使用Param 注解。

                如果Mapper接口形参中有多个参数,需要通过@Param 注解为每一个形参起名称(说明:如果是基于官方骨架创建的springboot项目,接口编译时会保留方法的形参名,@Param注解可以省略(#{形参名}))

                字节码文件中保留了参数                

        

八. XML映射配置文件

        1. 在mybatis中,既可以通过注解配置SQL 语句,也可以通过XML配置文件配置SQL语句。

        2.默认规则:

                (1) XML映射文件的名称与mapper接口名称一致,并且将xml映射文件和mapper接口放置在相同包下(同包同名)

                (2) XML映射文件的namespace属性为Mapper接口全限定名一致

                (3) XML映射文件中SQL语句的ID与mapper接口中的方法名一致,并保持返回类型一致

                入门_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.wyyzs.mapper.EmpMapper">

    <!--查询所有数据-->
    <select id="findAll" resultType="com.wyyzs.pojo.Emp">
        select * from emp
    </select>

</mapper>

        3.  在mybatis的开发中,倒底使用注解开发还是XML开发?

                使用mybatis的注解,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用xml来配置映射语句,官方说明:入门_MyBatis中文网

九. XML映射文件-辅助配置

        1. 配置XML文件映射文件的位置

                

# 配置mybatis的mapper文件位置
mybatis.mapper-locations=classpath:mapper/*.xml

        2. MybatisX

                MybatisX是一款基于IDEA的快速开发Mybatis的插件,为效率而生。

                

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

BUUCTF [ZJCTF 2019]EasyHeap

前置知识点: unlink知识点和手法-CSDN博客 [ZJCTF 2019]EasyHeap [ZJCTF 2019]EasyHeap 1.准备 2.ida分析 main函数 int __fastcall __noreturn main(int argc, const char **argv, const char **envp) {int n3; // eaxchar buf[8]; // [rsp0h] [rbp-10h] BYREFunsigned …

机器学习AI精准预测复合材料性能、材料结构设计优化;数据驱动加速新材料研发,百年难遇的组合打破科研壁垒!

在人工智能与复合材料技术融合的背景下&#xff0c;复合材料的研究和应用正迅速发展&#xff0c;创新解决方案层出不穷。从复合材料性能的精确预测到复杂材料结构的智能设计&#xff0c;从数据驱动的材料结构优化到多尺度分析&#xff0c;人工智能技术正以其强大的数据处理能力…

apache http client连接池实现原理

在java开发中我们经常会涉及到http 请求接口&#xff0c;一般有几种方式&#xff1a; java自带的 HttpURLConnectionokHttpClientapache http client 一般我们使用apache http client会比较多点&#xff0c;在代码中会进行如下调用方式&#xff1a; private static class Htt…

MD5加密(Java)

首先来看数据库里的一张员工信息表&#xff1a; 问题&#xff1a; 员工表中的密码是明文存储&#xff0c;安全性太低。 解决思路&#xff1a; 将明文密码加密后存储&#xff0c;提高安全性。 加密方式有很多&#xff0c;这里简单介绍 MD5加密方式 &#xff1a; (详细解释请转…

[攻防世界] easyphp writeup

知识点 科学计数法的妙用 9e9 指定结尾MD5值的爆破array_search() 函数用于在数组中搜索某个值&#xff0c;并返回对应的键名。如果找不到该值&#xff0c;则返回 false 默认值匹配&#xff1a;可以利用整数绕过字符串匹配机制stricttrue时&#xff0c;数据类型和值都需要匹配…

如何不规范的设置密码

上来就干 当我们使用服务器的时候&#xff0c;有时候需要一些非常简单的密码&#xff0c;来方便使用&#xff0c;但是自己完全可控的环境下&#xff0c;我们希望我们的密码足够的简单&#xff0c;比如&#xff0c;可能它的密码就是123&#xff0c;或者是1&#xff1f; 但是当你…

分享全国数字人才技能提升师资培训班 第五期邀请函

线下&#xff08;广州班&#xff09;&#xff1a; 大模型与AIGC多模态技术应用实战 线下&#xff08;青岛班&#xff09;&#xff1a; Deepseek教学应用与智能体开发实战 线上班&#xff08;十二大专题&#xff09;&#xff1a; DeepSeek大模型教学应用实战 大模型与AIGC技…

【Spring AI集成实战】基于NVIDIA LLM API构建智能聊天应用:从配置到函数调用全解析

【Spring AI集成实战】基于NVIDIA LLM API构建智能聊天应用&#xff1a;从配置到函数调用全解析 前言 在人工智能应用开发领域&#xff0c;大语言模型&#xff08;LLM&#xff09;的集成能力至关重要。NVIDIA作为全球领先的GPU厂商&#xff0c;其LLM API提供了对Meta Llama-3.…

Redis实战-缓存篇(万字总结)

前言&#xff1a; 今天结合黑马点评这个项目&#xff0c;讲下有关Redis缓存的一些内容&#xff0c;例如缓存更新策略&#xff0c;缓存穿透&#xff0c;雪崩和击穿等。 今日所学&#xff1a; 什么是缓存缓存更新策略缓存穿透缓存雪崩缓存击穿缓存工具封存 目录 1.什么是缓存…

Python学习笔记--Django 表单处理

注意&#xff1a;本笔记基于python 3.12,django 5版本&#xff0c;不同版本使用上有些许差别。 HTML表单是网站交互性的经典方式。下面介绍如何用Django对用户提交的表单数据进行处理。 HTTP 请求 HTTP协议以"请求&#xff0d;回复"的方式工作。客户发送请求时&am…

历年福州大学保研上机真题

2025福州大学保研上机真题 2024福州大学保研上机真题 2023福州大学保研上机真题 在线测评链接&#xff1a;https://pgcode.cn/problem?classification1 螺旋矩阵 题目描述 给定一个整数 n n n&#xff0c;要求打印出一个 n n n \times n nn 的螺旋矩阵。 例如&#xff…

大模型学习笔记day2 LoRA微调

LORA的核心思想基准模型不进行变化&#xff0c;我额外引入一部分参数来做专属内容处理&#xff0c;同时加上原有模型的推理能力&#xff0c;这部分新增加的的内容就是要训练出来的参数矩阵。 本征维度&#xff08;Intrinsic Dimension&#xff09;&#xff1a;是指数据或空间中…

Maven-概述-介绍安装

目录 1.项目对象模型 2.依赖管理模型 3.仓库&#xff1a;用于存储资源&#xff0c;管理各种jar包 4.本地仓库路径 5.Maven配置本地仓库 5.1在Maven路径下新建文件夹用于本地仓库存储 5.2 复制本地仓库路径 5.3 找到配置文件路径&#xff0c;使用VSCode方式打开 5.4 新…

GitHub Page填写域名显示被占用

问题描述 在Github上使用github page搭建个人博客&#xff0c;在项目中的Settings->Pages页面里面填写个人的域名时&#xff0c;出现如下报错信息&#xff0c;显示域名被占用情况 The custom domain example.com is already taken. If you are the owner of this domain, c…

java高级 -动态代理

动态代理的概念 动态代理是一种在运行时生成代理对象的机制&#xff0c;无需手动编写代理类。 代理就类似于中介公司&#xff0c;为明星置办各种前期准备。例如歌声需要开演唱会唱歌&#xff0c;那么此时就需要代理对象进行置办场地&#xff0c;设备&#xff0c;然后明星只需要…

机器学习算法:线性回归

1. 基础概念 线性回归是一种用于建模连续型目标变量&#xff08;如价格、销量、温度&#xff09;与一个或多个特征变量&#xff08;如面积、广告投入、时间&#xff09;之间线性关系的统计方法。 核心思想&#xff1a;找到一条直线&#xff08;或超平面&#xff09;&#xff0…

常见小问题(Open Folder as PyCharm Project)

1.删除pycharm鼠标右键快捷键打开项目 winr键打开&#xff0c;输入regedit&#xff0c;运行注册器 找到下面的路径&#xff1a;计算机\HKEY_CLASSES_ROOT\Directory\Background\shell\PyCharm 删除即可

第四十四节:目标检测与跟踪-模板匹配

一、引言 模板匹配的核心思想是通过在输入图像中搜索与预定义模板最相似的区域来定位目标。这种方法计算效率高、实现简单,特别适用于目标外观变化不大且背景相对简单的场景。本文将深入探讨模板匹配的原理、OpenCV中的实现方法、优化技巧以及实际应用案例。 二、模板匹配基础…

vue+ThreeJs 创建过渡圆圈效果

嗨&#xff0c;我是小路。今天主要和大家分享的主题是“vueThreeJs 创建过渡圆圈效果”。 今天在做着色器过渡效果练习&#xff0c;发现出现了很多新的函数&#xff0c;这些都超出了js之外&#xff0c;需要更多的掌握和学习。以下是自己的复盘和梳理。 1.获取距离 定…

MySQL:12_视图

视图 跟事务里讲的视图没有任何关系 视图是一个虚拟表&#xff0c;其内容由查询定义。同真实的表一样&#xff0c;视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表&#xff0c;基表的数据变化也会影响到视图。 一.基本使用 创建视图 create view 视图名 …