php 实现留言本增删改查功能_SpringBoot+Mybatis实现增删改查

SpringBoot整合Mybatis

1.看下我的目录结构

77f821991c15f5a30c7ffb5999814b0a.png

2.新建数据库

DROP TABLE IF EXISTS `test`;
CREATE TABLE `test`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `email` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `like` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

3.配置

yml的相关配置

spring:
  datasource:
    name: mytest
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: root
    url: jdbc:mysql://localhost:3306/mytest?useSSL=false&characterEncoding=utf8&serverTimezone=GMT%2B8

mybatis:
  type-aliases-package: sloth.zhang.test.domain
  mapper-locations: classpath:/mapper/*.xml

4.新建实体类

User.java

package sloth.zhang.test.domain;
import lombok.Data;
/**
 * @author Yoga zhang
 * @Type User.java
 * @date 2020/9/2 9:16
 */
@Data
public class User {
    private Integer id;
    private String name;
    private String password;
    private String email;
    private String aihao;
}

5.Dao层的编写

UserDao.java

package sloth.zhang.test.dao;
import org.apache.ibatis.annotations.Mapper;
import sloth.zhang.test.domain.User;
import java.util.List;
/**
 * @author Yoga zhang
 * @Type UserDao.java
 * @date 2020/9/2 9:24
 */
@Mapper
public interface UserDao {
    List<User>  selectAll();
    User selectById(Integer id);
    Integer delete(Integer id);
    Integer update(User user);
    Integer insert(User user);
}

UserMapper.xml

<?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="sloth.zhang.test.dao.UserDao">

    <!-- 通用查询映射结果 -->
    <resultMap id="User" type="sloth.zhang.test.domain.User">
        <id column="id" property="id" />
        <result column="name" property="name" />
        <result column="password" property="password" />
        <result column="email" property="email" />
        <result column="aihao" property="aihao" />
    </resultMap>

    <select id="selectAll" resultType="sloth.zhang.test.domain.User" >
        select id,name,password,email,aihao from test
    </select>
    <select id="selectById" resultType="sloth.zhang.test.domain.User">
        select id,name,password,email,aihao
        from test
        where id=#{id}
    </select>
    <insert id="insert">
        insert into test(name,password,email,aihao) values (#{name},#{password},#{email},#{aihao})
    </insert>
    <delete id="delete">
        delete from test where id=#{id}
    </delete>
    <update id="update">
        update test set name=#{name},password=#{password},email=#{email},aihao=#{aihao}  where id=#{id}
    </update>
</mapper>

6.Service层的编写

UserService.java

package sloth.zhang.test.service;
import sloth.zhang.test.domain.User;
import sloth.zhang.test.dto.ServiceResult;
import java.util.List;
/**
 * @author Yoga zhang
 * @Type UserService.java
 * @date 2020/9/2 9:23
 */
public interface UserService {
    ServiceResult selectAll();
    ServiceResult selectById(Integer id);
    ServiceResult delete(Integer id);
    ServiceResult update(User user);
    ServiceResult insert(User user);
}

UserServiceImpl.java

package sloth.zhang.test.service.impl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import sloth.zhang.test.dao.UserDao;
import sloth.zhang.test.domain.User;
import sloth.zhang.test.dto.ServiceResult;
import sloth.zhang.test.service.UserService;
import java.util.Collection;
import java.util.List;
/**
 * @author Yoga zhang
 * @Type UserServiceImpl.java
 * @date 2020/9/2 9:23
 */
@Service
public class UserServiceImpl implements UserService {
    @Autowired
    UserDao userDao;
    @Override
    public ServiceResult selectAll(){
        List<User> users= userDao.selectAll();
        if (!CollectionUtils.isEmpty(users)){
            return ServiceResult.success(users);
        }
        return ServiceResult.error("未查询到数据");
    }
    @Override
    public ServiceResult selectById(Integer id) {
        User user=userDao.selectById(id);
        if (user!=null){
            return ServiceResult.success(user);
        }
        return ServiceResult.error("未查询到数据");
    }
    @Override
    public ServiceResult delete(Integer id) {
        return ServiceResult.success(userDao.delete(id));

    }
    @Override
    public ServiceResult update(User user) {
        Integer res=userDao.update(user);
        if (res!=0) {
            return ServiceResult.success("修改成功");
        }
        return ServiceResult.error("修改用户失败");
    }
    @Override
    public ServiceResult insert(User user) {
        Integer res=userDao.insert(user);
        if (res!=0) {
            return ServiceResult.success("保存成功");
        }
        return ServiceResult.error("保存用户失败");
    }
}

7.Controller层的编写

UserController.java

package sloth.zhang.test.controller;
import jdk.nashorn.internal.objects.annotations.Getter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.*;
import sloth.zhang.test.domain.User;
import sloth.zhang.test.dto.ApiResponse;
import sloth.zhang.test.dto.ServiceResult;
import sloth.zhang.test.enums.ResultEnum;
import sloth.zhang.test.service.UserService;
/**
 * @author Yoga zhang
 * @Type UserController.java
 * @date 2020/9/2 9:22
 */
@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    UserService userService;
    @GetMapping(value = "/getById")
    public ApiResponse selectById(Integer id){
        if(StringUtils.isEmpty(id)){
            return ApiResponse.error(ResultEnum.PARAM_ERROR);
        }
        ServiceResult serviceResult = userService.selectById(id);
        if (serviceResult.isSuccess()){
            return ApiResponse.success(serviceResult.getResult());
        }
        return ApiResponse.error(ResultEnum.USER_NOT_EXIST);
    }

    @GetMapping(value = "/getAll")
    public ApiResponse selectAll(){
        ServiceResult serviceResult=userService.selectAll();
        if (serviceResult.isSuccess()){
            return ApiResponse.success(serviceResult.getResult());
        }
        return ApiResponse.error(ResultEnum.PARAM_ERROR);
    }

    @PostMapping(value = "/update")
    public ApiResponse update(User user){
        ServiceResult serviceResult=userService.update(user);
        if (serviceResult.isSuccess()){
            return ApiResponse.success(serviceResult.getResult());
        }
        return ApiResponse.error(serviceResult.getMessage());
    }

    @PostMapping(value = "/insert")
    public ApiResponse insert(User user){
        ServiceResult serviceResult=userService.insert(user);
        if (serviceResult.isSuccess()){
            return ApiResponse.success(serviceResult.getResult());
        }
        return ApiResponse.error(serviceResult.getMessage());
    }

    @DeleteMapping(value = "/delete")
    public ApiResponse delete(Integer id){
        ServiceResult serviceResult = userService.delete(id);
        if (serviceResult.isSuccess()){
            return ApiResponse.success(serviceResult.getResult());
        }
        return ApiResponse.error(ResultEnum.USER_NOT_EXIST);
    }
}

8.枚举类相关代码

ApiResponse.java

package sloth.zhang.test.dto;
import sloth.zhang.test.enums.ResultEnum;
/**
 * 控制层通用结构
 * @author wangqianlong
 * @create 2019-05-01 19:05
 */
public class ApiResponse<T> {
    private Integer code;
    private String msg;
    private T data;
    public static <T> ApiResponse<T> success(T object) {
        ApiResponse<T> apiResponse = new ApiResponse<>();
        apiResponse.setData(object);
        apiResponse.setCode(200);
        apiResponse.setMsg("ok");
        return apiResponse;
    }
    public static <T> ApiResponse<T> error(String msg) {
        ApiResponse<T> apiResponse = new ApiResponse<>();
        apiResponse.setCode(500);
        apiResponse.setMsg(msg);
        return apiResponse;
    }
    public static <T> ApiResponse<T> success(T object, ResultEnum resultEnum) {
        ApiResponse<T> apiResponse = new ApiResponse<>();
        apiResponse.setData(object);
        apiResponse.setCode(resultEnum.getCode());
        apiResponse.setMsg(resultEnum.getMessage());
        return apiResponse;
    }
    public static <T> ApiResponse<T> error(Integer code, String msg) {
        ApiResponse<T> apiResponse = new ApiResponse<>();
        apiResponse.setCode(code);
        apiResponse.setMsg(msg);
        return apiResponse;
    }
    public static <T> ApiResponse<T> error(ResultEnum resultEnum) {
        ApiResponse<T> apiResponse = new ApiResponse<>();
        apiResponse.setCode(resultEnum.getCode());
        apiResponse.setMsg(resultEnum.getMessage());
        return apiResponse;
    }
    public Integer getCode() {
        return code;
    }
    public void setCode(Integer code) {
        this.code = code;
    }
    public String getMsg() {
        return msg;
    }
    public void setMsg(String msg) {
        this.msg = msg;
    }
    public T getData() {
        return data;
    }
    public void setData(T data) {
this.data = data;
    }
}

ServiceResult.java

package sloth.zhang.test.dto;
import lombok.Data;
/**
 * 服务接口通用结构
 *
 * @author wangqianlong
 * @create 2019-05-01 19:05
 */
@Data
public class ServiceResult<T> {
    private boolean success;
    private String message;
    private T result;
    public ServiceResult(boolean success) {
        this.success = success;
    }
    public ServiceResult(boolean success, String message) {
        this.success = success;
        this.message = message;
    }
    public ServiceResult(boolean success, String message, T result) {
        this.success = success;
        this.message = message;
        this.result = result;
    }
    public static <T> ServiceResult<T> success(T result) {
        ServiceResult<T> serviceResult = new ServiceResult<>(true);
        serviceResult.setResult(result);
        return serviceResult;
    }
    public static <T> ServiceResult<T> error(String message) {
        ServiceResult<T> serviceResult = new ServiceResult<>(false);
        serviceResult.setMessage(message);
        return serviceResult;
    }
    public boolean isSuccess() {
        return success;
    }
    public void setSuccess(boolean success) {
        this.success = success;
    }
    public String getMessage() {
        return message;
    }
    public void setMessage(String message) {
        this.message = message;
    }
    public T getResult() {
        return result;
    }
    public void setResult(T result) {
        this.result = result;
    }
}

ResultEnum.java

package sloth.zhang.test.enums;
import lombok.Getter;
import lombok.Setter;
/**
 * @author Yoga zhang
 * @Type ResultEnum.java
 * @date 2020/9/2 12:52
 */
@Getter
public enum ResultEnum {
    SUCCESS(200,"成功"),
    USER_NOT_EXIST(201,"用户不存在"),
    PARAM_ERROR(501,"参数错误"),
    ERROR(500,"错误")
    ;
    private Integer code;
    private String message;
    ResultEnum(Integer code, String message) {
        this.code = code;
        this.message = message;
    }
}

注意事项

- dao-->mapper.xnl-->service中的方法名最好复制,不要重新输入。

- 对于更新,删除,插入方法最好使用整数型来修饰,因为数据库对于这些方法只存在行数的变化。可以通过数据库返回的整数来判断是否成功操作数据库。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot和MyBatis是一种常见的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的持久层框架。SpringBoot和MyBatis可以很好地协作,用于开发各种类型的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); } } 以上就是利用SpringBoot和MyBatis完成增删操作的详细步骤,可参考实际开发需求进行编写。 ### 回答3: Spring Boot 是一个快速开发框架,它提供了很多默认配置,可以帮助开发者快速地搭建一个项目。MyBatis 是一个持久层框架,可以帮助我们更加方便地操作数据库。Spring Boot 和 MyBatis 结合起来使用,可以帮助我们更加方便地实现数据库增删操作。 一、环境搭建 首先需要在 pom.xml 文件中引入 Spring Boot 和 MyBatis 的依赖。 ``` <!--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 Boot 和 MyBatis 结合,实现数据库增删操作的具体步骤。通过使用注解来创建实体对象和 Mapper,能够让我们更加方便地进行数据库操纵。同时,在进行数据库操作时,需要注意事务的处理,避免出现数据异常的情况。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值