修改逻辑问题出来方案(在判断用户名相同的同时,在执行修改用户信息时如果用户名相同可以修改其它数据,但是用户名不作为修改)

Posted ckfeng

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了修改逻辑问题出来方案(在判断用户名相同的同时,在执行修改用户信息时如果用户名相同可以修改其它数据,但是用户名不作为修改)相关的知识,希望对你有一定的参考价值。

使用layui实现前台页面,实现用户的增删改查

环境参数

  • 开发工具:IDEA
  • 基础环境:Maven+JDK8
  • 主要技术:SpringBoot、redis、mysql、mybatis-plus、swagger框架与layui前段框架
  • SpringBoot版本:2.2.6

实现步骤如下:

1.添加依赖

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!-- mybatisPlus 核心库 -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.0.6</version>
        </dependency>

        <!-- thymeleaf模板引擎 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>

        <!--redis-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

        <!--    mysql驱动包    -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
            <version>5.1.41</version>
        </dependency>

        <!-- 引入阿里数据库连接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.6</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>

        <!--mybatis-plus 代码生成器依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.3.1.tmp</version>
        </dependency>

        <!--  swagger 依赖   -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>RELEASE</version>
        </dependency>

        <!-- shiro -->
        <dependency>
            <groupId>org.apache.shiro</groupId>
            <artifactId>shiro-spring</artifactId>
            <version>1.4.0</version>
        </dependency>
        <!-- thymeleaf模板引擎和shiro框架的整合 -->
        <dependency>
            <groupId>com.github.theborakompanioni</groupId>
            <artifactId>thymeleaf-extras-shiro</artifactId>
            <version>2.0.0</version>
        </dependency>

        <!--  热部署   -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
        </dependency>

        <dependency>
            <groupId>io.swagger</groupId>
            <artifactId>swagger-annotations</artifactId>
            <version>1.5.22</version>
        </dependency>
        <dependency>
            <groupId>io.swagger</groupId>
            <artifactId>swagger-models</artifactId>
            <version>1.5.22</version>
        </dependency>

        <!--json  jar相关jar包-->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
            <version>2.9.0</version>
        </dependency>

        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
            <version>2.9.7</version>
        </dependency>

        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.9.7</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.23</version>
        </dependency>

        <dependency>
            <groupId>org.freemarker</groupId>
            <artifactId>freemarker</artifactId>
            <version>2.3.30</version>
        </dependency>


        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

 

2.业务service层如下:

package com.ckf.springboot_mysql_redis.service;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ckf.springboot_mysql_redis.entity.Users;
import com.baomidou.mybatisplus.extension.service.IService;
import com.ckf.springboot_mysql_redis.model.ResultFormat;
import io.swagger.models.auth.In;

/**
 * <p>
 * 服务类
 * </p>
 *
 * @author 安详的苦丁茶
 * @since 2020-05-02
 */
public interface UsersService extends IService<Users> {

    /**
     * 全查询用户信息
     *
     * @return
     */
    IPage<Users> selectUsersList(Page<Users> page);

    /**
     * 添加用户
     *
     * @param users
     * @return
     */
    ResultFormat saveUsers(Users users);

    /**
     * 修改用户
     *
     * @param users
     * @return
     */
    Integer updateUsers(Users users);

    /**
     * 删除用户
     *
     * @param userId
     * @return
     */
    Integer deleteUsersId(Integer userId);

}

 

3. service实现层如下:

 /**
     * 修改
     *
     * @param users
     * @return
     */
    @Override
    public Integer updateUsers(Users users) {
        logger.info("-----------------进入service实现层 修改用户信息-----------------");
        /**
         * 查询标签名称是否存在
         * 如果存在那就返回提示已经存在
         * 如果不存在那就修改
         */
        if (users != null) {
            if (users.getUserId() != null && !users.getUserName().isEmpty()) {
                Users pgLabelsByIdInfo = usersMapper.selectById(users.getUserId());
                AbstractWrapper wrapper = new QueryWrapper();
                wrapper.eq("user_name", users.getUserName());
                Users pgLabelsByNameInfo = usersMapper.selectOne(wrapper);

                /**
                 * 如果通过id查询的用户信息与前台传过来的名称一致
                 * 可修改其它数据
                 */
                if (pgLabelsByIdInfo != null) {
                    logger.info("pgLabelsByIdInfo={}", pgLabelsByIdInfo);
                    if (pgLabelsByIdInfo.getUserName().equals(users.getUserName())) {
                        Integer updateById = usersMapper.updateById(users);
                        if (updateById > 0) {
                            redisUtil.set("users:" + users.getUserId(), users);
                            return 200;
                        }
                    }
                }

                /**
                 * 从前台传过来的用户名称与id查询的名称不一致
                 * 再通过名称查询的数据为空就可以修改
                 */
                if (pgLabelsByNameInfo != null) {
                    logger.info("pgLabelsByNameInfo={}", pgLabelsByNameInfo);
                    if (!pgLabelsByNameInfo.getUserName().equals(pgLabelsByIdInfo.getUserName())) {
                        return 101;
                    }
                }

            }
        }

        /**
         * 如果用户名名称不一致就修改成 不存在的用户名称
         */
        Integer updateById = usersMapper.updateById(users);
        if (updateById > 0) {
            redisUtil.set("label:" + users.getUserName(), users);
            return 200;
        }

        return 100;
    }

 

4.controller层如下:

    /**
     * 修改用户信息
     *
     * @param users
     * @return
     */
    @ApiOperation("修改用户信息接口")
    @PutMapping("/update")
    @ResponseBody
    public ResultFormat updatePgSorts(Users users) {

        users.getRegisterTime();
        users.setUpdateTime(TimeUtitl.dateTime());

        Integer insert = usersService.updateUsers(users);

        if (insert == 101) {
            logger.info("用户名已存在");
            return ResultUtil.error(101, "用户名已经存在");
        }
        if (insert == 200) {
            logger.info("修改成功");
            return ResultUtil.success();
        }

        return ResultUtil.error(100, "修改失败");

    }

 

效果图如下:

修改:

技术图片

 

 

 首页:

技术图片

 

 

码云地址:https://gitee.com/ckfeng/springboot_mysql_redis.git

 

以上是关于修改逻辑问题出来方案(在判断用户名相同的同时,在执行修改用户信息时如果用户名相同可以修改其它数据,但是用户名不作为修改)的主要内容,如果未能解决你的问题,请参考以下文章

UE4多个分支版本兼容相同的工程dll

UE4多个分支版本兼容相同的工程dll

Redis专题7:分布式方案

按钮条件逻辑配置化的可选技术方案

微服务架构的身份验证解决方案

基于编辑距离纯逻辑实现相似地址聚类