解决使用MP插入oracle或者pgsql主键不能为空的问题

 当我们使用MP的插入时,目标是Pgsql数据库,主键为空的时候,数据库设置为自增,那么就会报错,主键不能为空

解决办法:在代码中加入拦截器:

@Component
public class CustomIdGenerator implements IdentifierGenerator {
    @Override
    public Long nextId(Object entity) {
        return UUID.fastUUID().getMostSignificantBits();
    }
}

并且在对应实体类的id属性上的自增类型设置为默认为雪花算法自增

@TableId(value = "id", type = IdType.ASSIGN_ID)
    private Long id;

这时候数据库就不用设置主键自增了

pgsql中,表格不能插入相同内容的原因可能是因为表格中存在唯一约束或主键约束。唯一约束要求表格中的某个列的值是唯一的,而主键约束要求表格中的某个列的值是唯一且非空的。当尝试插入相同内容时,pgsql会检测到违反了唯一约束或主键约束,从而导致插入失败。 要解决这个问题,你可以考虑以下几种方法: 1. 检查表格的约束:使用DESCRIBE或SHOW CREATE TABLE语句来查看表格的约束,确认是否存在唯一约束或主键约束。 2. 检查插入数据:确保插入数据不与表格中已有的数据重复。可以使用SELECT语句来查询表格中的数据,以确保插入数据是唯一的。 3. 更新已有数据:如果你想插入数据与表格中已有的数据相同,你可以考虑使用UPDATE语句来更新已有的数据,而不是插入重复的数据。 请注意,以上方法只是一些常见的解决方案,具体的解决方法可能因你的表格结构和需求而有所不同。如果问题仍然存在,请提供更多的信息,以便我能够给出更具体的建议。 #### 引用[.reference_title] - *1* *2* *3* [复杂的pgsql触发器实现数据审计:记录行变更值](https://blog.csdn.net/qq_44833403/article/details/131563079)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值