【初学】SpringBoot+MyBatis实现增删改查(从创建项目开始)

1、springboot脚手架搭建(2.x)

环境配置
1、下载安装 jdk 1.8
2、下载安装 apache maven ( 3.8.1 )

大家不要嫌我复杂、啰嗦,如果不是初学者的话,这个文章对你也就没有用的(前期工作都很详细)

2、IDEA创建SpringBoot项目

打开 IDEA 点击 New Project,依次选择下面的操作
在这里插入图片描述

接着点击 Next
在这里插入图片描述
spingboot的版本不要选太高

3、修改maven仓库路径

然后在 setting 里设置 maven 路径
在这里插入图片描述
设置编码,改为 utf-8
在这里插入图片描述

4、连接数据库

改文件后缀,将 application 的后缀改为 yml
文件所在路径:src / main /resources / application.yml

application.yml

server:
  port: 9090

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/permissions?serverTimezone=GMT%2b8
    username: root
    password: 123456

server: port:9090 这个是自定义端口号
permissions:是我自己的数据库名
username:数据库连接账号
password:数据库连接密码

5、构造统一返回结果 Result.java

springboot 文件夹下创建 common
具体路径:com / example / springboot / common / Result.java

后面会大量使用自定义的返回结果,所以这个不可少
在这里插入图片描述

Result.java

/**
 * 这段是我个人包的路径,如果不一样,则要改成你自己的
 */
package com.example.springboot.common;

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

@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder

/**
 * 功能:接口统一返回包装类
 */
public class Result {

    public static final String CODE_SUCCESS = "200";
    public static final String CODE_AUTH_ERROR = "401";
    public static final String CODE_SYS_ERROR = "500";

    private String code;
    private String msg;
    private Object data;

    public static Result success() {
    
        return Result.builder().code(CODE_SUCCESS).msg("请求成功").build();
    }

    public static Result success(Object data) {
        return new Result(CODE_SUCCESS, "请求成功", data);
    }

    public static Result error(String msg) {
        return new Result(CODE_SYS_ERROR, msg, null);
    }

    public static Result error(String code, String msg) {
        return new Result(code, msg, null);
    }

    public static Result error() {
        return new Result(CODE_SYS_ERROR, "系统错误", null);
    }

}

6、在数据库建立用户表

在 navicat 里面创建数据库 permissions

数据库名:permissions
字符集:utf8mb4
排序规则:utf8mb4_unicode_ci

新建user表:
直接在数据库里面点击查询、新建查询,然后执行语句就行

CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '用户名',
  `password` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '密码',
  `name` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '姓名',
  `phone` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '电话',
  `email` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '邮箱',
  `address` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '地址',
  `avatar` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '头像',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='用户表';

添加 username 为唯一索引:点击表然后右键、设计表、索引
在这里插入图片描述

7、创建实体类(User.java)

com / example / springboot 下创建 entity
再在 entity 下创建 User.java
在这里插入图片描述

User.java

package com.example.springboot.entity;
import lombok.Data;

@Data

public class User {
    private Integer id;
    private String username;
    private String password;
    private String name;
    private String email;
    private String phone;
    private String address;
    private String avatar;
}

8、创建映射器( UserMappe.java)

在 com / example / springboot 下创建 mapper 文件包
然后新建 UserMapper 文件
在这里插入图片描述
以此类推:

在 com / example / springboot 下创建 service 包 然后在 service
下创建UserService.java 文件

在 com / example / springboot 下创建 controller 包 然后在 service
下创建UserController.java 文件

9、添加信息(增)

插入数据
在这里插入图片描述
UserMapper

package com.example.springboot.mapper;

import com.example.springboot.entity.User;
import org.apache.ibatis.annotations.*;

public interface UserMapper {

    // 用户新增
    @Insert("insert into `user` (username, password, name, phone, email, address, avatar) " +
            "values (#{username}, #{password}, #{name}, #{phone}, #{email}, #{address}, #{avatar})")
    void insert(User user);

}


UserService.java
在这里插入图片描述
结合上捕获异常

@Autowired
UserMapper userMapper;

public Result insertUser(User user) {
    try {
        userMapper.insert(user);
    } catch (Exception e) {
        if (e instanceof DuplicateKeyException) {
            return Result.error("插入数据库错误");
        } else {
            return Result.error("系统错误");
        }
    }
    return Result.success();
}

UserController.java
在这里插入图片描述
写控制层(接口)

package com.example.springboot.controller;

import com.example.springboot.common.Result;
import com.example.springboot.entity.User;
import com.example.springboot.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;

public class UserController {
    @Autowired
    UserService userService;

    /**
     * 新增用户信息
     */
    @PostMapping("/add")
    public Result add(@RequestBody User user) {
        userService.insertUser(user);
        return Result.success();
    }
}

10、修改信息(改)

根据id修改
在这里插入图片描述
UserMapper
在 “增” 的基础上添加以下代码

@Update("update `user` set username = #{username}, password = #{password}, name= #{name}, phone = #{phone}, " +
        "email = #{email}, address = #{address}, avatar = #{avatar} where id = #{id}")
void updateUser(User user);

UserService
在这里插入图片描述

public void updateUser(User user) {
    userMapper.updateUser(user);
}

UserController

在这里插入图片描述

/**
 * 修改用户信息
 */
@PutMapping("/update")
public Result update(@RequestBody User user) {
    userService.updateUser(user);
    return Result.success();
}

11、删除信息

  1. 单个删除

UserMapper

// 单个的删除用户
@Delete("delete from `user` where id = #{id}")
void deleteUser(Integer id);

UserService

// 单个删除
public void deleteUser(Integer id) {
    userMapper.deleteUser(id);
}

UserController

/**
 * 删除用户信息
 */
@DeleteMapping("/delete/{id}")
public Result delete(@PathVariable Integer id) {
    userService.deleteUser(id);
    return Result.success();
}

  1. 批量删除

UserService
先导入包
在这里插入图片描述
然后写

// 批量删除
public void batchDeleteUser(List<Integer> ids) {
    for (Integer id : ids) {
        userMapper.deleteUser(id);  // 7  - 8
    }
}

UserController

/**
 * 批量删除用户信息
 */
@DeleteMapping("/delete/batch")
public Result batchDelete(@RequestBody List<Integer> ids) {
    userService.batchDeleteUser(ids);
    return Result.success();
}

12、查询信息(查)

  1. 简单的全部查询

在这里插入图片描述

UserMapper

 @Select("select * from `user` order by id desc")
List<User> selectAll();

UserService

public List<User> selectAll() {
    return userMapper.selectAll();
}

UserController

/**
 * 查询全部用户信息
 */
@GetMapping("/selectAll")
public Result selectAll() {
    List<User> userList = userService.selectAll();
    return Result.success(userList);
}
  1. 单个的条件查询

按照条件的单条查询(此处以id查询为例) 想要按照什么查询可以参考这个,把 id 改为其他就好;
注意:这个只能返回一条,也就是查询的是唯一的,比如 id 是唯一的就可以查询,如果是 name
就有多个数据,这个时候会报错,解决方法就是不设置返回一个数据,而是一个 list 对象 极力推荐使用返回一个对象的代码

UserMapper

// 跟据id查询单个用户信息(区别:返回一个数据,查到多个就报错)
@Select("select * from `user` where id = #{id} order by id desc")
User selectById(Integer id);


// 根据name查询多个用户信息(区别于:返回的是List对象)
@Select("select * from `user` where name = #{name} order by id desc")
List<User> selectByName(String name);

UserService

// 跟据id查询单个用户信息(区别:返回一个数据,查到多个就报错)
public User selectById(Integer id) {
    return userMapper.selectById(id);
}


// 根据name查询多个用户信息(区别于:返回的是List对象)
public List<User> selectByName(String name) {
    return userMapper.selectByName(name);
}

UserController

/**
 * 根据ID查询单个用户信息
 * 跟据id查询单个用户信息(区别:返回一个数据,查到多个就报错)
 */
@GetMapping("/selectById/{id}")
public Result selectById(@PathVariable Integer id) {
    User user = userService.selectById(id);
    return Result.success(user);
}


/**
 * 根据name查询多个用户信息(区别于:返回的是List对象)
 */
@GetMapping("/selectByName/{name}")
public Result selectByName(@PathVariable String name) {
    List<User> userList = userService.selectByName(name);  // 不知道多少条数据就返回一个List对象
    return Result.success(userList);
}
  1. 多个的条件查询

UserMapper

// 多条件查询用户信息(区别:可同时跟据 username、name 查询),下面参数加上@Param()注解
@Select("select * from `user` where username = #{username} and name = #{name} order by id desc")
List<User> selectByMore(@Param("username") String username, @Param("name") String name);

UserService

// 多条件查询用户信息(区别:可同时跟据 username、name 查询)
public List<User> selectByMore(String username, String name) {
    return userMapper.selectByMore(username, name);
}

UserController

/**
 * 多条件查询用户信息(区别:可同时跟据 username、name 查询)
 */
@GetMapping("/selectByMore")
public Result selectByMore(@RequestParam String username, @RequestParam String name) {
    List<User> userList = userService.selectByMore(username, name);  // 不知道多少条数据就返回一个List对象
    return Result.success(userList);
}
  1. 简单模糊查询

UserMapper

下面sql语句使用 and 就是需要同时满足两个条件才能查询出来,如果是 or 的话就是要满足其中一个就好

// 多条件模糊查询用户信息
@Select("select * from `user` where username like concat('%', #{username}, '%') and name like concat('%', #{name}, '%') order by id desc")
List<User> selectByObscure(String username, String name);

UserService

// 多条件模糊查询
public List<User> selectByObscure(String username, String name) {
    return userMapper.selectByObscure(username, name);
}

UserController

/**
 * 多条件模糊查询
 */
@GetMapping("/selectByMore")
public Result selectByObscure(@RequestParam String username, @RequestParam String name) {
    List<User> userList = userService.selectByObscure(username, name);  // 不知道多少条数据就返回一个List对象
    return Result.success(userList);
}
  1. 分页多条件模糊查询

在 common 下创建 Page.java 文件
在这里插入图片描述Page

package com.example.springboot.common;
import lombok.Data;
import java.util.List;

@Data
public class Page<T> {
    private Integer total;
    private List<T> list;
}

UserMapper

// 多条件模糊查询
@Select("select * from `user` where username like concat('%', #{username}, '%') and name like concat('%', #{name}, '%') order by id desc limit #{skipNum}, #{pageSize}")
List<User> selectByPage(@Param("skipNum") Integer skipNum, @Param("pageSize")Integer pageSize, @Param("username") String username, @Param("name") String name);

// 与多条件模糊查询一起的 sql 跟据条件统计总数:selectCountByPage
@Select("select count(id) from `user` where username like concat('%', #{username}, '%') and name like concat('%', #{name}, '%') order by id desc")
int selectCountByPage(@Param("username") String username, @Param("name") String name);

UserService

// 多条件模糊查询
public Page<User> selectByPage(Integer pageNum, Integer pageSize, String username, String name) {
    Integer skipNum = (pageNum - 1) * pageSize;

    Page<User> page = new Page<>();
    List<User> userList = userMapper.selectByPage(skipNum, pageSize, username, name);
    Integer total = userMapper.selectCountByPage(username, name);
    page.setTotal(total);
    page.setList(userList);
    return page;
}

UserController

/**
 * 多条件模糊查询
 * pageNum:当前页码
 * pageSize:每页查询的个数
 */
@GetMapping("/selectByPage")
public Result selectByPage(@RequestParam Integer pageNum,
                           @RequestParam Integer pageSize,
                           @RequestParam String username,
                           @RequestParam String name) {
    Page<User> page = userService.selectByPage(pageNum, pageSize, username, name);
    return Result.success(page);
}

到这里就结束了,这个只是给初学者了解的,这种 增删改查部分内容 在 MyBatis-Plus 里都不用写,UserMapper继承BaseMapper就行

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring BootMyBatis是一种常见的Java Web开发框架,可以用来实现增删改查操作。具体步骤如下: 1. 配置数据库连接信息,包括数据库驱动、数据库URL、用户名和密码等。 2. 创建实体类,用于映射数据库表结构。 3. 创建Mapper接口,定义增删改查方法。 4. 创建Mapper.xml文件,编写SQL语句,实现Mapper接口中定义的方法。 5. 创建Service层,调用Mapper接口中的方法,实现业务逻辑。 6. 创建Controller层,接收请求,调用Service层中的方法,返回响应。 7. 配置Spring Boot启动类,启动应用程序。 以上是实现增删改查的基本步骤,具体实现过程需要根据具体业务需求进行调整。 ### 回答2: SpringBoot是一个用于构建基于Spring的应用程序的框架,它是建立在Spring之上的一种轻量级解决方案。MyBatis是一种开源的持久化框架,它是基于Java的持久层框架。SpringBootMyBatis可以很好地协作,用于开发各种类型的Web应用程序。在SpringBoot中使用MyBatis实现增删改查操作非常简单,一下是具体操作: 1.数据库配置 首先需要进行数据库配置,可在application.properties(或application.yml)中进行配置,SpringBoot会自动加载这些配置。 spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driverClassName=com.mysql.cj.jdbc.Driver 2.依赖配置 pom文件中添加MyBatis和MySQL连接驱动的依赖,如下: <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.3</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.23</version> </dependency> 3.实体类编写 创建实体类并添加注解@Table(name="表名")、@Id等等,如下: @Table(name="userinfo") public class User { @Id private Integer id; private String name; private Integer age; private String address; //省略setter和getter方法 } 4.DAO接口编写 编写DAO接口,如下: public interface UserDao { List<User> getAll(); User getById(Integer id); void insert(User user); void update(User user); void delete(Integer id); } 5.Mapper文件编写 在src/main/resources/mapper下创建Mapper文件,定义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.demo.dao.UserDao"> <resultMap id="userMap" type="com.example.demo.model.User"> <id property="id" column="id"/> <result property="name" column="name"/> <result property="age" column="age"/> <result property="address" column="address"/> </resultMap> <select id="getAll" resultMap="userMap"> SELECT id, name, age, address FROM userinfo </select> <select id="getById" resultMap="userMap"> SELECT id, name, age, address FROM userinfo WHERE id = #{id} </select> <insert id="insert" parameterType="com.example.demo.model.User"> INSERT INTO userinfo(name, age, address) VALUES (#{name}, #{age}, #{address}) </insert> <update id="update" parameterType="com.example.demo.model.User"> UPDATE userinfo SET name = #{name}, age = #{age}, address = #{address} WHERE id = #{id} </update> <delete id="delete" parameterType="int"> DELETE FROM userinfo WHERE id = #{id} </delete> </mapper> 6.DAO接口实现 编写DAO接口实现类UserDaoImpl,代码如下: @Repository public class UserDaoImpl implements UserDao { @Autowired private SqlSessionTemplate sqlSessionTemplate; private final String NAMESPACE = "com.example.demo.dao.UserDao"; @Override public List<User> getAll() { return this.sqlSessionTemplate.selectList(NAMESPACE + ".getAll"); } @Override public User getById(Integer id) { return this.sqlSessionTemplate.selectOne(NAMESPACE + ".getById",id); } @Override public void insert(User user) { this.sqlSessionTemplate.insert(NAMESPACE + ".insert",user); } @Override public void update(User user) { this.sqlSessionTemplate.update(NAMESPACE + ".update",user); } @Override public void delete(Integer id) { this.sqlSessionTemplate.delete(NAMESPACE + ".delete",id); } } 7.Controller层编写 创建Controller层方法,调用DAO层方法,如下: @RestController @RequestMapping("user") public class UserController { @Autowired private UserDao userDao; @GetMapping(value="/getAll") public List<User> getAll() { return userDao.getAll(); } @GetMapping(value="/getById/{id}") public User getById(@PathVariable("id") Integer id) { return userDao.getById(id); } @PostMapping(value="/insert") public void insert(@RequestBody User user) { userDao.insert(user); } @PutMapping(value="/update") public void update(@RequestBody User user) { userDao.update(user); } @DeleteMapping(value="/delete/{id}") public void delete(@PathVariable("id") Integer id) { userDao.delete(id); } } 以上就是利用SpringBootMyBatis完成增删改查操作的详细步骤,可参考实际开发需求进行编写。 ### 回答3: Spring Boot 是一个快速开发框架,它提供了很多默认配置,可以帮助开发者快速地搭建一个项目MyBatis 是一个持久层框架,可以帮助我们更加方便地操作数据库。Spring BootMyBatis 结合起来使用,可以帮助我们更加方便地实现数据库增删改查操作。 一、环境搭建 首先需要在 pom.xml 文件中引入 Spring BootMyBatis 的依赖。 ``` <!--Spring Boot 依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.4.5</version> </dependency> <!--Mybatis 依赖--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.0</version> </dependency> ``` 其次,在 application.properties 文件中配置数据源相关信息。 ``` # 数据库配置 spring.datasource.url= jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver #Mybatis 配置 mybatis.mapper-locations=classpath:mapper/*.xml mybatis.type-aliases-package=com.example.demo.entity ``` 二、创建实体对象和 Mapper 在 Spring Boot 中,我们可以利用注解来快速地完成实体对象和 Mapper 的创建。 1. 创建实体对象 ``` @Data @AllArgsConstructor @NoArgsConstructor public class User { private Integer id; private String name; private Integer age; } ``` 2. 创建 Mapper ``` @Mapper @Component public interface UserMapper { List<User> selectAll(); User selectById(Integer id); int insert(User user); int update(User user); int deleteById(Integer id); } ``` 三、实现增删改查 1. 实现插入操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public boolean insert(User user) { int result = userMapper.insert(user); return result == 1; } } ``` 2. 实现查询操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public List<User> selectAll() { return userMapper.selectAll(); } @Override public User selectById(Integer id) { return userMapper.selectById(id); } } ``` 3. 实现更新操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public boolean update(User user) { int result = userMapper.update(user); return result == 1; } } ``` 4. 实现删除操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public boolean deleteById(Integer id) { int result = userMapper.deleteById(id); return result == 1; } } ``` 以上就是 Spring BootMyBatis 结合,实现数据库增删改查操作的具体步骤。通过使用注解来创建实体对象和 Mapper,能够让我们更加方便地进行数据库操纵。同时,在进行数据库操作时,需要注意事务的处理,避免出现数据异常的情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值