MyBatis查询数据库(2)

这篇具有很好参考价值的文章主要介绍了MyBatis查询数据库(2)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言🍭

一、增删查改操作🍭

1、查🍉

Ⅰ、mapper接口:🍓

Ⅱ、UserMapper.xml 查询所有用户的具体实现 SQL:🍓

Ⅲ、进行单元测试🍓

2、增、删、改操作🍉

Ⅰ、增🍓

添加用户🍒

添加用户并且返回自增 id🍒

Ⅱ、改🍓

根据id修改用户名🍒

开启 MyBatis sql 日志打印🍒

Ⅲ、删🍓

二、在单元测试时不污染数据库🍭 


前言🍭

❤️❤️❤️SSM专栏更新中,各位大佬觉得写得不错,支持一下,感谢了!❤️❤️❤️

Spring + Spring MVC + MyBatis_冷兮雪的博客-CSDN博客

上篇我们写了一个简单的根据id进行查询,知道了如何去进行查询,下面来仔细讲讲增删改查操作。

一、增删查改操作🍭

下面操作会使用到Spring Boot单元测试,可以先看:

Spring Boot单元测试_spring boot 单元测试_冷兮雪的博客-CSDN博客

1、查🍉

查询所有的用户:

Ⅰ、mapper接口:🍓

package com.example.ssmdemo1.mapper;

import com.example.ssmdemo1.entity.Userinfo;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper//需要添加 @Mapper 注解
public interface UserMapper {
    /**
     * 根据用户id查询用户信息
     * @param id
     * @return
     */
    Userinfo getUserById(@Param("id") Integer id);

    //查询所有的用户
    List<Userinfo> getAll();
}

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

Ⅱ、UserMapper.xml 查询所有用户的具体实现 SQL:🍓

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

使用$进行传递参数可能会SQL注入,所以大部分情况下是使用#的 

<?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.example.ssmdemo1.mapper.UserMapper">
    <select id="getUserById" resultType="com.example.ssmdemo1.entity.Userinfo">
        select * from userinfo where id=${id}
    </select>
    <select id="getAll" resultType="com.example.ssmdemo1.entity.Userinfo">
        select * from userinfo
    </select>
</mapper>

Ⅲ、进行单元测试🍓

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

在UserMapperTest中就有了getAll的测试代码:

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

添加单元测试业务逻辑 

package com.example.ssmdemo1.mapper;

import com.example.ssmdemo1.entity.Userinfo;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;

import static org.junit.jupiter.api.Assertions.*;

@SpringBootTest//1、表明当前单元测试是运行在Spring Boot环境中的
class UserMapperTest {
    //2、注入测试对象
    @Autowired
    private UserMapper userMapper;

    @Test
    void getUserById() {
        //3、添加单元测试的业务代码
        Userinfo userinfo=userMapper.getUserById(1);
        System.out.println(userinfo);
        //判断1是否等于2 简单断言
        Assertions.assertEquals("admin",userinfo.getUsername());
    }

    @Test
    void getAll() {
        List<Userinfo> list=userMapper.getAll();
        Assertions.assertEquals(1,list.size());//断言判断list集合里面是否只有一条数据,即查询数据库中只有一个用户
    }
}

 测试正确:

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

 如果我们没有设置resultType,则 MyBatis无法自动将查询结果映射到Java对象,这就会导致单元测试失败并报错。

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

2、增、删、改操作🍉

与查询操作都是一样的,只是使用的标签不一样:

  • <insert>标签:插入语句
  • <update>标签:修改语句
  • <delete>标签:删除语句

Ⅰ、增🍓

添加用户🍒

①、在接口(UserMapper)中声明方法

    Integer add(Userinfo user);

②、UserService

public Integer getAdd(Userinfo user) {return userMapper.add(user);}

③、在xml中提供实现

<insert id="add">
        insert into userinfo(username,password) values(#{username},#{password})
</insert>

#{} 进行赋值使用的是对象中的属性。

注意:对应的不是数据库的字段,而是程序类中的属性。

④、controller 实现代码:

@RequestMapping(value = "/add",method = RequestMethod.POST)
    public Integer add(@RequestBody Userinfo user){
        return userService.getAdd(user);
    }

⑤、单元测试

@Test
    void add() {
        //伪代码,构建对象并设置对应的值
        //本来是前端传值过来
        Userinfo userinfo=new Userinfo();
        userinfo.setUsername("张三");
        userinfo.setPassword("123456");
        //调用mybatis 添加方法执行添加操作
        int result=userMapper.add(userinfo);
        Assertions.assertEquals(1,result);
    }

 单元测试成功,可以去看数据库也添加了一条数据

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

但是如果我们去获取这个用户的id,就会报空指针异常:

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

添加用户并且返回自增 id🍒

 如果我们想在添加用户的时候同时去获取他的id,具体实现如下:

①、在接口(UserMapper)中声明方法

Integer addGetid(Userinfo user);

②、UserService

public Integer addGetid(Userinfo user) {return userMapper.addGetid(user);}

③、在xml中提供实现

<insert id="addGetid" useGeneratedKeys="true" keyProperty="id">
        insert into userinfo(username,password) values(#{username},#{password})
</insert>
  • useGeneratedKeys:这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如:像 MySQL 和 SQL Server 这样的关系型数据库管理系统的自动递增字段),默认值:false。
  • keyColumn:设置生成键值在表中的列名,在某些数据库(像 PostgreSQL)中,当主键列 不是表中的第⼀列的时候,是必须设置的。如果⽣成列不止⼀个,可以用逗号分隔多个属性 名称。
  • keyProperty:指定能够唯⼀识别对象的属性,MyBatis会使用 getGeneratedKeys 的返回值或 insert 语句的 selectKey 子元素设置它的值,默认值:未设置(unset)。如果生成列不止⼀个,可以⽤逗号分隔多个属性名称。

④、controller 实现代码:

 @RequestMapping(value = "/add2", method = RequestMethod.POST)
    public Integer add2(@RequestBody Userinfo user) {
        userService.addGetid(user);
        return user.getId();
    }

⑤、单元测试

@Test
    void addGetid() {
        //伪代码,构建对象并设置对应的值
        //本来是前端传值过来
        Userinfo userinfo=new Userinfo();
        userinfo.setUsername("张三");
        userinfo.setPassword("123456");
        //调用MyBatis 添加方法执行添加操作 返回受影响的行数
        int result=userMapper.addGetid(userinfo);
        int id=userinfo.getId();//得到自增id(MyBatis自动赋值)
        System.out.println("id:"+id);
        Assertions.assertEquals(1,result);
    }

 一样的代码,就一行代码不同

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

Ⅱ、改🍓

根据id修改用户名🍒

①、在接口(UserMapper)中声明方法

/**
     * 修改用户
     * @param userinfo
     * @return
     */
    Integer upUserName(Userinfo userinfo);

②、在xml中提供实现

<update id="upUserName">
        update userinfo set username=#{username} where id=#{id}
</update>

③、单元测试

将之前添加的张三修改成为李四

@Test
    void upUserName() {
        // 构建测试数据
        Userinfo userinfo = new Userinfo();
        userinfo.setId(9);
        userinfo.setUsername("李四");
        int result = userMapper.upUserName(userinfo);
        System.out.println("修改:" + result);
        Assertions.assertEquals(1, result);
    }

修改成功: 

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

如果我们需要在控制台看到SQL语句,需要去配置文件进行配置,因为这默认是隐藏MyBatic生成SQL语句的细节

开启 MyBatis sql 日志打印🍒

①、添加配置文件

# 开启 mybatis sql 日志打印
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
logging.level.com.example.demo=debug

②、重新运行单元测试

@Test
    void upUserName() {
        // 构建测试数据
        Userinfo userinfo = new Userinfo();
        userinfo.setId(9);
        userinfo.setUsername("张三");
        int result = userMapper.upUserName(userinfo);
        System.out.println("修改:" + result);
        Assertions.assertEquals(1, result);
    }

 执行成功:

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

结论: 可以看到这个就是jdbc链接,这个SQL写法也是jdbc的写法,也就是说mybatis是基于jdbc的,MyBatis使用了JDBC来与数据库进行交互,它也简化了JDBC的使用,提供了更方便的数据库访问方式。。

建议大家在开发阶段是开启SQL的打印,可以更好的帮助你找到错误。

Ⅲ、删🍓

①、在接口(UserMapper)中声明方法

int delById(@Param("id") Integer id);

②、在xml中提供实现

<delete id="delById">
        delete from userinfo where id=#{id}
</delete>

 ③、单元测试

将id为9的用户删除:

@Test
    void delById() {
        int id=9;
        int result=userMapper.delById(id);
        System.out.println("删除:"+result);
        Assertions.assertEquals(1,result);
    }

删除成功: 

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

二、在单元测试时不污染数据库🍭 

在需要的地方添加注解:@Transactional(可以修饰方法也可以修饰类)

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

如下面,去修饰UserMapper整个类:

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言

MyBatis查询数据库(2),Spring + Spring MVC + MyBatis,mybatis,java,开发语言文章来源地址https://www.toymoban.com/news/detail-602858.html

到了这里,关于MyBatis查询数据库(2)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MyBatis查询数据库(1)

    ❤️❤️❤️SSM专栏更新中,各位大佬觉得写得不错,支持一下,感谢了!❤️❤️❤️ Spring + Spring MVC + MyBatis_冷兮雪的博客-CSDN博客 经过前⾯的学习咱们 Spring 系列的基本操作已经实现的差不多了,接下来,咱们来学习更重要的知识,将前端传递的数据存储起来,或者查询

    2024年02月15日
    浏览(74)
  • MyBatis查询数据库(2)

    目录 前言🍭 一、增删查改操作🍭 1、查🍉 Ⅰ、mapper接口:🍓 Ⅱ、UserMapper.xml 查询所有用户的具体实现 SQL:🍓 Ⅲ、进行单元测试🍓 2、增、删、改操作🍉 Ⅰ、增🍓 添加用户🍒 添加用户并且返回自增 id🍒 Ⅱ、改🍓 根据id修改用户名🍒 开启 MyBatis sql 日志打印🍒 Ⅲ、

    2024年02月16日
    浏览(45)
  • MyBatis查询数据库(3)

    ❤️❤️❤️SSM专栏更新中,各位大佬觉得写得不错,支持一下,感谢了!❤️❤️❤️ Spring + Spring MVC + MyBatis_冷兮雪的博客-CSDN博客 前面我们讲解了MyBatis增删改查基本操作,下面我们来深入了解MyBatis其中不同和需要注意的地方。 下面我们来实现⼀下根据用户 id 查询用户

    2024年02月14日
    浏览(52)
  • MyBatis 查询数据库、持久层框架简介

    MyBatis是一款优秀的持久层框架,支持自定义SQL、存储过程以及高级映射。它通过简单的XML或注解来配置和映射原始类型、接口和Java POJO为数据库中的记录。

    2024年02月12日
    浏览(59)
  • MyBatis查询数据库之一(概念+创建项目+基础交互)

    目录 1.MyBatis是什么? 2.为什么学习MyBatis? 3. 怎么学 MyBatis 4.第⼀个MyBatis查询 4.1 添加MyBatis框架支持 4.1.1老项目添加MyBatis 4.1.2 新项目添加MyBatis 4.2 配置连接字符串和MyBatis 4.2.1 配置连接字符串 4.2.2 配置 MyBatis 中的 XML 路径 5. 使用 MyBatis 的操作模式操作数据库 5.1 添加实体类

    2024年02月13日
    浏览(52)
  • 【Spring Boot】数据库持久层框架MyBatis — MyBatis简介

    本节首先会介绍什么是ORM、什么是MyBatis、MyBatis的特点以及核心概念,最后介绍MyBatis是如何启动、如何加载配置文件的? ORM(Object Relational Mapping,对象关系映射)是为了解决面向对象与关系数据库存在的互不匹配现象的一种技术。简单地说,ORM通过使用描述对象和数据库之

    2024年02月11日
    浏览(47)
  • MyBatis 查询数据库之二(增、删、改、查操作)

    目录 1. 配置打印 MyBatis 执行的SQL 2. 查询操作 2.1 通过用户 ID 查询用户信息、查询所有用户信息 (1) Mapper 接口 (2)UserMapper.xml 查询所有用户的具体实现 SQL (3)进行单元测试 3. 增加操作 3.1 在 mapper(interface)里面添加增加方法的声明 3.2 在 XMl 中添加 标签和增加的 sql 代码 3.3 生成

    2024年02月14日
    浏览(47)
  • 【Spring Boot】数据库持久层框架MyBatis — Spring Boot构建MyBatis应用程序

    Spring Boot是用于快速构建Spring应用程序的框架。MyBatis是一种Java持久化框架,可以帮助开发人员轻松地管理数据库。将Spring Boot与MyBatis结合使用可以使开发人员更容易地创建和管理数据库应用程序。 以下是使用Spring Boot构建MyBatis应用程序的步骤: 添加MyBatis依赖项:在项目的

    2024年02月10日
    浏览(56)
  • 【MyBatis学习】MyBatis操纵数据库进行查询操作 ?MyBatis与JDBC想比怎么样,赶快与我一起探索吧 ! ! !

    前言: 大家好,我是 良辰丫 ,从今天开始我们就要进入MyBatis的学习了,请君与我一起操纵数据库,MyBatis到底是什么呢?我们慢慢往下瞧! ! !💌💌💌 🧑个人主页:良辰针不戳 📖所属专栏:javaEE进阶篇之框架学习 🍎励志语句:生活也许会让我们遍体鳞伤,但最终这些伤口会成为我

    2024年02月09日
    浏览(51)
  • Spring日志完结篇,MyBatis操作数据库(入门)

    目录 Spring可以对日志进行分目录打印 日志持久化(让日志进行长期的保存) MyBatis操作数据库(优秀的持久层框架) MyBatis的写法 开发规范: 单元测试的写法 传递参数 他的意思是说spring相关只打印INFO级别的标准,但是他也能获取到debug级别的日志 日志设置颜色(只能控制控制

    2024年02月04日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包