Spring Boot快速入门(五):使用MyBatis(注解形式)进行数据库操作

原文地址:https://lierabbit.cn/articles/7

添加依赖

新建项目选择web,MyBatis,MySQL三个依赖 

对于已存在的项目可以在bulid.gradle加入,spring boot将会帮你自动配置好

compile(‘org.springframework.boot:spring-boot-starter-data-jpa‘)
compile(‘org.springframework.boot:spring-boot-starter-web‘)
runtime(‘mysql:mysql-connector-java‘)
testCompile(‘org.springframework.boot:spring-boot-starter-test‘)

配置基本信息

然后在src/main/resources/application.properties下添加基本配置

#数据库连接地址
spring.datasource.url=jdbc:mysql://localhost:3306/mybaits?useSSL=false
#数据库账号
spring.datasource.username=root
#数据库密码
spring.datasource.password=123456zxc
#数据库驱动
spring.datasource.driver-class-name=com.mysql.jdbc.Driver 

创建实体

创建一个User实体,包含id、name(姓名)、age(年龄)属性

public class User
{
    private Long id;
    private String name;
    private Integer age;

    public User()
    {
    }

    public User(String name, Integer age)
    {
        this.name = name;
        this.age = age;
    }

    public Long getId()
    {
        return id;
    }

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

    public String getName()
    {
        return name;
    }

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

    public Integer getAge()
    {
        return age;
    }

    public void setAge(Integer age)
    {
        this.age = age;
    }
} 

创建数据访问接口

创建一个userMapper接口,进行数据库操作,添加@Mapper注解

import org.apache.ibatis.annotations.*;

import java.util.List;

@Mapper//这是一个MyBatis的数据库操作接口
public interface UserMapper
{
    @Select("SELECT * FROM user WHERE name = #{name}")
    User findByName(@Param("name") String name);

    @Select("SELECT * FROM user WHERE name LIKE #{name}")
    List<User> findByNameLike(@Param("name") String name);

    @Insert("INSERT INTO user(name, age) VALUES(#{name}, #{age})")
    int insert(@Param("name") String name, @Param("age") Integer age);

    @Update("UPDATE user SET age = #{age} WHERE name = #{name}")
    int update(@Param("name") String name, @Param("age") Integer age);

    @Delete("DELETE FROM user WHERE name = #{name}")
    int delete(@Param("name") String name);

    @Select("SELECT COUNT(*) FROM user")
    int countAll();
}

单元测试

在src/test/java/你的包名/你的项目名ApplicationTests编写对应的单元测试来验证编写的内容是否正确

import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.annotation.Rollback;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.transaction.annotation.Transactional;

@RunWith(SpringRunner.class)
@SpringBootTest
@Transactional//声明事务,配合Rollback
public class MybatisApplicationTests
{
    @Autowired
    private UserMapper userMapper;

    @Test
    @Rollback//测试结束回滚数据,保证测试单元每次运行的数据环境独立
    public void testUser()
    {
        userMapper.insert("QQQ",1);
        userMapper.insert("WWW",2);
        userMapper.insert("EEE",3);
        userMapper.insert("AAA",4);
        userMapper.insert("SSS",5);
        userMapper.insert("DDD",6);
        userMapper.insert("ZZZ",7);
        userMapper.insert("XXX",8);
        userMapper.insert("CCC",9);
        userMapper.insert("SSS213",10);

        // 测试findAll, 查询所有记录
        Assert.assertEquals(10, userMapper.countAll());

        // 测试findByName, 查询姓名为AAA的User
        Assert.assertEquals(4, userMapper.findByName("AAA").getAge().longValue());

        // 更新CCC用户的年龄为15
        userMapper.update("CCC",15);

        // 测试findByName, 查询姓名为CCC的User的年龄是否为15
        Assert.assertEquals(15, userMapper.findByName("CCC").getAge().longValue());

        // 测试删除姓名为AAA的User
        userMapper.delete("AAA");

        // 测试findAll, 查询所有记录, 验证上面的删除是否成功
        Assert.assertEquals(9, userMapper.countAll());

        // 测试findAll, 查询名字有S的有几个
        Assert.assertEquals(2,userMapper.findByNameLike("%S%").size());
    }

}

测试结果

源码地址:https://github.com/LieRabbit/SpringBoot-mybatis

原文地址:https://lierabbit.cn/articles/7

原文地址:https://www.cnblogs.com/lierabbit/p/8320520.html

时间: 2024-11-08 19:21:32

Spring Boot快速入门(五):使用MyBatis(注解形式)进行数据库操作的相关文章

微服务的入门级微框架Spring Boot快速入门

详情请交流  QQ  709639943 00.微服务的入门级微框架Spring Boot快速入门 00.基于java的微信公众号二次开发视频教程 00.leetcode 算法 面试 00.北风网 零基础到数据(大数据)分析专家-首席分析师 00.快速上手JMeter 00.Jmeter 00.2017年Java web开发工程师成长之路 00.R语言速成实战 00.R语言数据分析实战 00.Python+Django+Ansible Playbook自动化运维项目实战 00.Java深入微服务

Spring Boot快速入门(二):http请求

原文地址:https://lierabbit.cn/articles/4 一.准备 postman:一个接口测试工具 创建一个新工程 选择web 不会的请看Spring Boot快速入门(一):Hello Spring Boot 二.开始 新建java类RequestCtrl 1.添加一个all方法,使用@RequestMapping注解,可以处理所有的http请求 @RestController//这是一个控制器并只返回数据不寻找视图 public class RequestCtrl { @R

Spring Boot 2.X(五):MyBatis 多数据源配置

前言 MyBatis 多数据源配置,最近在项目建设中,需要在原有系统上扩展一个新的业务模块,特意将数据库分库,以便减少复杂度.本文直接以简单的代码示例,如何对 MyBatis 多数据源配置. 准备 创建数据库 db_test SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for t_user -- -------------------------

Spring Boot 快速入门 史上最简单

1.Spring Boot 概述 Spring Boot 是所有基于 Spring 开发的项目的起点.Spring Boot 的设计是为了让你尽可能快的跑起来 Spring 应用程序并且尽可能减少你的配置文件. 2.什么是 Spring Boot Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.用我的话来理解,就是spring boot其实不是什么新

Spring Boot 快速入门

什么是spring boot Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.用我的话来理解,就是spring boot其实不是什么新的框架,它默认配置了很多框架的使用方式,就像maven整合了所有的jar包,spring boot整合了所有的框架(不知道这样比喻是否合适). 使用spring boot有什么好处 其实就是简单.快速.方便!平时如果我

Spring Boot快速入门 (一)

1.IDE工具的安装和使用 1.1.下载IDE Spring Tool Suite Eclipse 1.2.介绍 maven是学习Spring Boot必备之一 Spring Tool Suite可快速搭建Spring Boot项目 1.3.Spring Boot项目结构预览 2.RESTfull API简单项目的快速搭建 2.1.搭建一个简单的RESTfull API接口项目 2.2.引入spring-boot-starter-web 2.3.引入spring-boot-devtools 2.

Spring Boot快速入门

安装 安装依赖 maven是一个依赖管理工具,我们利用maven进行构建.创建一个maven项目,在pom.xml里面添加依赖项 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance&quo

【第一篇】spring boot 快速入门

1.开发环境 开发工具:IDEA2018.2.1 JDK:1.9 Maven : 3.3.9 操作系统:window 7 / window 10 2.项目结构 3.详细步骤 3.1 使用IDEA新建Maven空白项目 file->new->project,然后按照要求填好.如下: 点击finsh后会生成项目如下: 3.2 在pom.xml文件添加继承.依赖和插件配置 <!-- 默认继承 --> <parent> <groupId>org.springfram

Spring Boot 快速入门(一)

简介  相信很多人都接触spring框架很长时间了,每次搭建spring框架的时候都需要配置好多的jar.xml,做很多繁琐重复的配置,稍微不留神就会出现各种各样的问题,每次调试真的是香菇.蓝瘦啊. spring boot的出现帮助我们彻底解决了这些jar的依赖,只需要很少的配置就可以完成我们的开发工作,我们可以把自己的应用打包成jar,使用java -jar来运行spring web应用,spring boot集成了很多的web容器,后面都会慢慢讲到这些,今天我们就开始使用spring boo