Java---Mybatis详解二

news2025/1/11 23:40:07

雄鹰展翅凌空飞, 大江奔流不回头。 壮志未酬心未老, 豪情万丈任遨游。

巍巍高山攀顶峰, 滔滔黄河入海流。 风云变幻凭君舞, 踏遍天涯尽逍遥。

目录

一,环境准备

 二,删除

 三,删除(预编译SQL)

为什么性能更高?

为什么更安全?

 四,新增

五,更新

六,查询

七,条件查询

like 模糊匹配

一,环境准备

基于上一篇文章的环境Java---Mybatis详解一-CSDN博客 ,新增加一些数据:

INSERT INTO tb_user (username, password) VALUES ('user1', 'password123');
INSERT INTO tb_user (username, password) VALUES ('user2', 'password1233');
INSERT INTO tb_user (username, password) VALUES ('user3', 'password1234');
INSERT INTO tb_user (username, password) VALUES ('user4', 'password12345');
INSERT INTO tb_user (username, password) VALUES ('user5', 'password123456');

在单元测试中通过IOC依赖注入,来查询所插入的数据:

@SpringBootTest
class Demo1ApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void test() {
        List<UserBean> userBeanList = userMapper.findAll();
        userBeanList.stream().forEach(userBean -> {
            System.out.println(userBean.toString());
        });
    }

}

输出结果:

至此,环境准备完毕

 二,删除

要进行删除操作,首先要在之前创建的UserMapper中添加一个删除的接口:

@Mapper
public interface UserMapper {

    @Select("select * from tb_user")
    public List<UserBean> findAll();

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

注意:因为id是我们传入的参数,所以需要动态获取,springboot中使用#{id}来表示动态传入的参数

 在单元测试中根据依赖注入来调用删除方法:

@SpringBootTest
class Demo1ApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void test() {
        List<UserBean> userBeanList = userMapper.findAll();
        userBeanList.stream().forEach(userBean -> {
            System.out.println(userBean.toString());
        });
    }

    @Test
    public void testDel() {
        userMapper.deleteById(2);
    }

}

运行testDel方法后,查看数据库:

发现数据库中少了id为2的数据,所以删除成功了。

 三,删除(预编译SQL)

在springboot中配置mybatis的日志,可以指定输出日志到控制台。

在application.properties中添加配置项:

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/yz
spring.datasource.username=root
spring.datasource.password=1234

#配置mybatis的日志,指定输出到控制台
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

然后执行删除操作:

@SpringBootTest
class Demo1ApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void test() {
        List<UserBean> userBeanList = userMapper.findAll();
        userBeanList.stream().forEach(userBean -> {
            System.out.println(userBean.toString());
        });
    }

    @Test
    public void testDel() {
        userMapper.deleteById(3);
    }

}

然后我们就会在控制台看到删除的相关sql语句的日志: 

 预编译SQL有什么优势呢?

 为什么性能更高?

先看下没有预编译的情况:

 每执行一条sql语句,需要执行三次缓存

再来看一下预编译的情况:

通过预编译sql语句,只需要缓存一次即可,性能更高

为什么更安全?

先来看看什么是SQL注入:

SQL注入,是通过操作输入的数据来修改事先定义好的SQL语句,以达到执行代码对服务器进行攻击的方法。

预编译会将输入的内容整个的替换为? 从而防止SQL注入。

 四,新增

新增数据同样需要现在UserMapper中增加新增的接口

@Mapper
public interface UserMapper {

    @Select("select * from tb_user")
    public List<UserBean> findAll();

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

    //插入数据
    @Insert("insert into tb_user(username,password)"+" values (#{username},#{password})")
    public void insert(UserBean user);
}

在application.properties中添加插入测试方法:

@SpringBootTest
class Demo1ApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void test() {
        List<UserBean> userBeanList = userMapper.findAll();
        userBeanList.stream().forEach(userBean -> {
            System.out.println(userBean.toString());
        });
    }

    @Test
    public void testDel() {
        userMapper.deleteById(3);
    }

    @Test
    public void testInsert(){
        UserBean userBean = new UserBean();
        userBean.setUsername("袁震");
        userBean.setPassword("123456");
        userMapper.insert(userBean);
    }

}

运行之后,查看数据库表:

插入操作就完成了。

五,更新

更新数据同样需要在UserMapper中添加接口:

@Mapper
public interface UserMapper {

    @Select("select * from tb_user")
    public List<UserBean> findAll();

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

    //插入数据
    @Insert("insert into tb_user(username,password) values (#{username},#{password})")
    public void insert(UserBean user);

    //更新用户信息
    @Update("update tb_user set username =#{username},password =#{password} where id =#{id}")
    public void upDate(UserBean user);
}

在测试程序中添加测试代码:

@SpringBootTest
class Demo1ApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void test() {
        List<UserBean> userBeanList = userMapper.findAll();
        userBeanList.stream().forEach(userBean -> {
            System.out.println(userBean.toString());
        });
    }

    @Test
    public void testDel() {
        userMapper.deleteById(3);
    }

    @Test
    public void testInsert(){
        UserBean userBean = new UserBean();
        userBean.setUsername("袁震");
        userBean.setPassword("123456");
        userMapper.insert(userBean);
    }

    @Test
    public void testUpdate(){
        UserBean userBean = new UserBean();
        userBean.setId(6);
        userBean.setPassword("123456789");
        userBean.setUsername("袁震1");
        userMapper.upDate(userBean);
    }

}

运行后观察数据库:

修改成功

六,查询

在UserMapper中添加根据id查询用户信息接口:

@Mapper
public interface UserMapper {

    @Select("select * from tb_user")
    public List<UserBean> findAll();

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

    //插入数据
    @Insert("insert into tb_user(username,password) values (#{username},#{password})")
    public void insert(UserBean user);

    //更新用户信息
    @Update("update tb_user set username =#{username},password =#{password} where id =#{id}")
    public void upDate(UserBean user);

    //根据id查询用户信息
    @Select("select * from tb_user where id =#{id}")
    public UserBean findById(Integer id);
}

在测试程序中测试查询结果:

@SpringBootTest
class Demo1ApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void test() {
        List<UserBean> userBeanList = userMapper.findAll();
        userBeanList.stream().forEach(userBean -> {
            System.out.println(userBean.toString());
        });
    }

    @Test
    public void testDel() {
        userMapper.deleteById(3);
    }

    @Test
    public void testInsert(){
        UserBean userBean = new UserBean();
        userBean.setUsername("袁震");
        userBean.setPassword("123456");
        userMapper.insert(userBean);
    }

    @Test
    public void testUpdate(){
        UserBean userBean = new UserBean();
        userBean.setId(6);
        userBean.setPassword("123456789");
        userBean.setUsername("袁震1");
        userMapper.upDate(userBean);
    }

    @Test
    public void testFind(){
        UserBean userBean = userMapper.findById(6);
        System.out.println(userBean.toString());
    }

}

输出:

注意:

 解决方法:

七,条件查询

like 模糊匹配

在UserMapper中添加接口:

@Mapper
public interface UserMapper {

    @Select("select * from tb_user")
    public List<UserBean> findAll();

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

    //插入数据
    @Insert("insert into tb_user(username,password) values (#{username},#{password})")
    public void insert(UserBean user);

    //更新用户信息
    @Update("update tb_user set username =#{username},password =#{password} where id =#{id}")
    public void upDate(UserBean user);

    //根据id查询用户信息
    @Select("select * from tb_user where id =#{id}")
    public UserBean findById(Integer id);

    //条件查询用户信息 查询包含user的用户
    @Select("select * from tb_user where username like concat('%',#{name},'%')")
    public List<UserBean> findByName(String name);
}

 在测试程序中测试:

@SpringBootTest
class Demo1ApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void test() {
        List<UserBean> userBeanList = userMapper.findAll();
        userBeanList.stream().forEach(userBean -> {
            System.out.println(userBean.toString());
        });
    }

    @Test
    public void testDel() {
        userMapper.deleteById(3);
    }

    @Test
    public void testInsert(){
        UserBean userBean = new UserBean();
        userBean.setUsername("袁震");
        userBean.setPassword("123456");
        userMapper.insert(userBean);
    }

    @Test
    public void testUpdate(){
        UserBean userBean = new UserBean();
        userBean.setId(6);
        userBean.setPassword("123456789");
        userBean.setUsername("袁震1");
        userMapper.upDate(userBean);
    }

    @Test
    public void testFind(){
        UserBean userBean = userMapper.findById(6);
        System.out.println(userBean.toString());
    }

    @Test
    public void testFindByName(){
        List<UserBean> user = userMapper.findByName("user");
        System.out.println(user.toString());
    }

}

输出:

这样所有包含user的用户都查询出来了。

 

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

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

相关文章

[译]全栈Redux实战

本文乱译自一篇英文博文&#xff08;Full-Stack Redux Tutorial&#xff09;&#xff0c;本人英语能力不足&#xff0c;技术能力有限&#xff0c;如有错误&#xff0c;多多包涵。 #关于ReduxReactImmutable的测试先行开发综合指南 Redux是最近发生在js界令人兴奋的事儿。它把…

Elasticsearch 第四期:搜索和过滤

序 2024年4月&#xff0c;小组计算建设标签平台&#xff0c;使用ES等工具建了一个demo&#xff0c;由于领导变动关系&#xff0c;项目基本夭折。其实这两年也陆陆续续接触和使用过ES&#xff0c;两年前也看过ES的官网&#xff0c;当时刚毕业半年多&#xff0c;由于历史局限性导…

耗材分类功能解析:智慧校园的必备利器

在智慧校园的资产管理架构中&#xff0c;耗材分类功能是确保日常运营物资有效管理的关键组成部分&#xff0c;它致力于提高耗材使用的效率和经济性。此功能通过智能化、精细化的管理手段&#xff0c;对校园内各种易耗品进行科学分类与跟踪。 耗材分类功能首先建立在对校园日常运…

Prometheus 监控服务器

Prometheus概述 组件化设置&#xff1a;nginx ,ceph , Prometheus 部署Prometheus服务器 配置时间 安装Prometheus服务器 访问web页面&#xff1a;http://192.168.88.5:9090/ 添加被监控端 监控方式&#xff1a; 拉取&#xff1a;pull。监控端联系被监控端&#xff0c;采集数…

Android sdk 安装已经环境配置

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;Android ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 正文 一、下载 二、安装 三、环境配置 我的其他博客 正文 一、下载 1、大家可去官网下载 因为需要魔法 所以就不展示了 2、去下面这…

MySQL期末答辩—仓库管理系统

仓库管理系统&#xff1a;仓库管理系统是一种基于互联网对实际仓库的管理平台&#xff0c;旨在提供一个方便、快捷、安全的存取货物和查询商品信息平台。该系统通过在线用户登录查询&#xff0c;可以线上操作线下具体出/入库操作、查询仓库商品信息、提高仓库运作效率&#xff…

SPI 通信 协议

介绍&#xff1a; SPI&#xff08;Serial Peripheral Interface&#xff09;是由摩托罗拉公司开发的一种通用数据总线 四根通信线&#xff1a; SCK&#xff08;Serial Clock&#xff09; 时钟线MOSI&#xff08;Master Output Slave Input&…

粗糙度轮廓仪功能简介:一体型轮廓仪功能亮点

在精密制造和质量控制领域&#xff0c;表面粗糙度和轮廓的精确测量是至关重要的。一体型轮廓仪为这一需求提供了全面的解决方案。它采用超高精度纳米衍射光学测量系统、超高直线度研磨级摩擦导轨、高性能直流伺服驱动系统、高性能计算机控制系统技术&#xff0c;为用户提供了一…

90后懒人带娃的福音,小学生古诗词的神器——ChatMoney全能知识库AI软件

本文由 ChatMoney团队出品 因为工作需要&#xff0c;浅尝辄止般的用了一下ChatMoney全能知识库AI软件。一些长期积存的问题迎刃而解&#xff0c;但这只是一款企业级大模型功能的冰山一角。让自己尤为惊奇的是里面涵盖的各类资料系统&#xff0c;居然能助力宝妈宝爸带娃脱困。只…

AIGC对设计行业的影响与启发:AIGC设计能替代真正的设计师吗?

随着科技的飞速发展&#xff0c;人工智能生成内容&#xff08;AIGC&#xff09;技术在设计行业的应用日益广泛&#xff0c;引发了广泛的讨论和关注。AIGC以其高效、多样化的生成能力&#xff0c;为设计行业带来了前所未有的变革。然而&#xff0c;关于AIGC是否能替代真正的设计…

Rustdesk如何编译代码实现安装后不会显示主界面,不会在右下角出现托盘图标,作为后台服务运行

环境&#xff1a; Rustdesk1.1.9 问题描述&#xff1a; Rustdesk如何编译代码实现安装后不会显示主界面&#xff0c;不会在右下角出现托盘图标&#xff0c;作为后台服务运行 解决方案&#xff1a; 可以自定义进程名称和图标&#xff0c;不会显示主界面&#xff0c;不会在…

uboo对内存操作读写命令的基本使用

内存操作命令 直接对DRAM进行读写的操作,uboot常用的内存操作命令有md,nm,mm,mw,cp和cmp. md命令: 显示内存值 # md md - memory display Usage: md [.b, .w, .l, .q] address [# of objects] b:1个字节 byte w:2个字节 world l:4个字节 long of objects 以word 为单位的1…

搭建个人博客及错误记录

搭建个人博客及错误记录 文章目录 搭建个人博客及错误记录需要用到的网址2.推荐两个参考教学视频3.发布一篇博客个人主题配置的提醒localhost拒绝连接问题解决办法ssh -T gitgithub.com失败问题解决Deployer not found:git解决 可以根据目录解决遇到的相同问题 需要用到的网址 …

昇思25天学习打卡营第3天|yulang

今天主要学习03-张量Tensor&#xff0c;主要包含了处理创建张量、张量的属性、张量索引和张量运算&#xff0c;稀疏张量&#xff0c;有点看不太懂&#xff0c;感觉要开始入门到放弃了&#xff1f;张量在构建和训练深度学习模型中的实际应用&#xff0c;如卷积神经网络。 张量&a…

Vue入门-如何创建一个Vue实例

创建一个一个Vue实例总共分为四步&#xff1a; 1.创建一个容器 2.引包&#xff1a;地址栏搜索v2.cn.vuejs.org这是vue2的官网地址&#xff0c;把2去掉就是vue3的官网地址&#xff0c;我们的包分为开发版本和生产版本&#xff0c;开发版本包含完整的警告和调试模式生产版本删除…

【Python机器学习】算法链与管道——用预处理进行参数选择的注意项

对于许多机器学习算法&#xff0c;提供的特定数据表示非常重要。比如&#xff0c;首先对数据进行缩放&#xff0c;然后手动合并特征&#xff0c;再利用无监督机器学习来学习特征。因此&#xff0c;大多数机器学习应用不仅需要应用多个算法&#xff0c;而且还需要将许多不同的处…

BIOS中的设置虽然不少,但其实大部分时候只需进行一些简单的调整

序言 浏览BIOS可能会让人感到不知所措,因为要考虑的设置太多了。但是,你应该在BIOS中进行一些简单的调整,以提高系统的性能和稳定性。我们将向你展示其中的一些调整,并解释你可能想要使用它们的时间和原因。 用密码保护你的BIOS 虽然我们很小心地对用户帐户进行密码保护…

打卡第一天

今天是参加算法训练营的第一天&#xff0c;希望我能把这个训练营坚持下来&#xff0c;希望我的算法编程题的能力有所提升&#xff0c;不再面试挂了&#xff0c;面试总是挂编程题&#xff0c;记录我leetcode刷题数量&#xff1a; 希望我通过这个训练营能够实现两份工作的无缝衔接…

【Spring Boot】Java 持久层 API:JPA

Java 持久层 API&#xff1a;JPA 1.Spring Data1.1 主要模块1.2 社区模块 2.JPA3.使用 JPA3.1 添加 JPA 和 MySQL 数据库的依赖3.2 配置数据库连接信息 4.了解 JPA 注解和属性4.1 常用注解4.2 映射关系的注解4.3 映射关系的属性 5.用 JPA 构建实体数据表 1.Spring Data Spring…

【Linux】多线程(一万六千字)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 文章目录 前言 线程的概念 线程的理解(Linux系统为例) 在Linux系统里如何保证让正文部分的代码可以并发的去跑呢&#xff1f; 为什么要有多进程呢&#xff1f; 为…