目 录CONTENT

文章目录

生成MyBatis批量插入时,无数据插入,有数据更新的on duplicate key update语句

筱晶哥哥
2024-04-04 / 0 评论 / 0 点赞 / 119 阅读 / 14068 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2024-04-04,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

on duplicate key update 语句根据主键id或唯一键来判断当前插入是否已存在。

记录已存在时,只会更新on duplicate key update之后指定的字段。

我们在编码时这部分可能需要自己写,当然有的生成工具可能已经生成好了,字段太多的话,自己写起来很烦,以下我写了一个生成这部分代码的工具类。

假如我们的实体类为:

package com.itjing.springboot.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;

/**
 * 用户信息
 */
@TableName(value = "person_info")
public class PersonInfo {
    /**
     * 主键id
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    /**
     * 名称
     */
    @TableField(value = "user_name")
    private String userName;

    /**
     * 年龄
     */
    @TableField(value = "user_age")
    private Integer userAge;

    /**
     * 地址
     */
    @TableField(value = "user_address")
    private String userAddress;

    public static final String COL_ID = "id";

    public static final String COL_USER_NAME = "user_name";

    public static final String COL_USER_AGE = "user_age";

    public static final String COL_USER_ADDRESS = "user_address";

    /**
     * 获取主键id
     *
     * @return id - 主键id
     */
    public Integer getId() {
        return id;
    }

    /**
     * 设置主键id
     *
     * @param id 主键id
     */
    public void setId(Integer id) {
        this.id = id;
    }

    /**
     * 获取名称
     *
     * @return user_name - 名称
     */
    public String getUserName() {
        return userName;
    }

    /**
     * 设置名称
     *
     * @param userName 名称
     */
    public void setUserName(String userName) {
        this.userName = userName == null ? null : userName.trim();
    }

    /**
     * 获取年龄
     *
     * @return user_age - 年龄
     */
    public Integer getUserAge() {
        return userAge;
    }

    /**
     * 设置年龄
     *
     * @param userAge 年龄
     */
    public void setUserAge(Integer userAge) {
        this.userAge = userAge;
    }

    /**
     * 获取地址
     *
     * @return user_address - 地址
     */
    public String getUserAddress() {
        return userAddress;
    }

    /**
     * 设置地址
     *
     * @param userAddress 地址
     */
    public void setUserAddress(String userAddress) {
        this.userAddress = userAddress == null ? null : userAddress.trim();
    }

    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append(getClass().getSimpleName());
        sb.append(" [");
        sb.append("Hash = ").append(hashCode());
        sb.append(", id=").append(id);
        sb.append(", userName=").append(userName);
        sb.append(", userAge=").append(userAge);
        sb.append(", userAddress=").append(userAddress);
        sb.append("]");
        return sb.toString();
    }

    @Override
    public boolean equals(Object that) {
        if (this == that) {
            return true;
        }
        if (that == null) {
            return false;
        }
        if (getClass() != that.getClass()) {
            return false;
        }
        PersonInfo other = (PersonInfo) that;
        return (this.getId() == null ? other.getId() == null : this.getId().equals(other.getId()))
                && (this.getUserName() == null ? other.getUserName() == null : this.getUserName().equals(other.getUserName()))
                && (this.getUserAge() == null ? other.getUserAge() == null : this.getUserAge().equals(other.getUserAge()))
                && (this.getUserAddress() == null ? other.getUserAddress() == null : this.getUserAddress().equals(other.getUserAddress()));
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((getId() == null) ? 0 : getId().hashCode());
        result = prime * result + ((getUserName() == null) ? 0 : getUserName().hashCode());
        result = prime * result + ((getUserAge() == null) ? 0 : getUserAge().hashCode());
        result = prime * result + ((getUserAddress() == null) ? 0 : getUserAddress().hashCode());
        return result;
    }
}

生成代码:

package com.itjing.springboot.test;

import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.itjing.springboot.entity.PersonInfo;

import java.lang.reflect.Field;
import java.util.Arrays;
import java.util.List;
import java.util.Objects;
import java.util.concurrent.CopyOnWriteArrayList;

/**
 * 生成MyBatis批量插入时,无数据插入,有数据更新的on duplicate key update语句
 *
 * @author lijing
 * @date 2024-04-04
 */
public class GenerateCode {

    public static void main(String[] args) {

        Class<?> entityClass = PersonInfo.class;
        // 获取表名
        TableName tableName = entityClass.getAnnotation(TableName.class);
        // 获取属性
        Field[] declaredFields = entityClass.getDeclaredFields();
        List<String> dbFieldNameList = new CopyOnWriteArrayList<>();
        // 按属性设置sql字段
        Arrays.stream(declaredFields).forEach(field -> {
            TableField tableField = field.getAnnotation(TableField.class);
            if (Objects.nonNull(tableField)) {
                dbFieldNameList.add(tableField.value());
            }
        });
        StringBuilder updateSql = new StringBuilder();
        updateSql.append("on duplicate key update").append("\n");
        // String formatStr = "`{}` = if(isnull(values(`{}`)), `{}`, values(`{}`)),";
        String formatStr = "`{}` = values(`{}`),";
        dbFieldNameList.stream().forEachOrdered(fieldName -> {
            updateSql.append(StrUtil.format(formatStr, fieldName, fieldName, fieldName, fieldName)).append("\n");
        });
        // 去除最后一个逗号
        updateSql.delete(updateSql.length() - 2, updateSql.length());
        System.out.println(updateSql);
    }
}

结果:

on duplicate key update
`user_name` = values(`user_name`),
`user_age` = values(`user_age`),
`user_address` = values(`user_address`)
0

评论区