MybatisPlus添加数据自增主键失效,mysql自增主键失效

1、问题概述?

情况1:mysql数据库设置了自增主键,但是添加的时候,出现了长串的负数或者正数id,如:-109096962。

情况2:mysql数据库设置了自增主键,但是添加的时候,对象中的id有值,这个是在添加的时候会生效。

2、解决办法?

解决办法总体比较简单

【注意点1:@TableId(value = "id",type = IdType.AUTO)】

AUTO(0, “数据库ID自增”),
NONE(1, “该类型为未设置主键类型”),
INPUT(2, “用户输入ID”),

@Setter
@Getter
@AllArgsConstructor
@NoArgsConstructor
@ToString
@TableName("auto_autocasemenu")
public class Student{
    @TableId(value = "id",type = IdType.AUTO)
    private Integer id;//序号-主键自增
    private String  stu_name;
    private String  stu_sex;
    private String  stu_age;
    private String  stu_addr;
    private String  stu_pwd;
}

【注意点2:id不要赋值】

有些人认为id不给值,就是给id设置成0或者-1,这个都是不行的。需要设置成null;

Student stu=new Student();

stu.setStu_id(null);

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据引用,在建表语句中设置id为自增主键,可以使用auto_increment关键字。但需要注意的是,auto_increment是MySQL中的关键字,在Oracle数据库中并不支持自增主键的定义。 在Oracle数据库中,可以通过使用序列(Sequence)来实现自增主键的功能。以下是一个示例的建表语句: ``` CREATE TABLE aaa ( id NUMBER PRIMARY KEY, type NUMBER DEFAULT 0 NOT NULL, create_time TIMESTAMP DEFAULT SYSDATE NOT NULL, update_time TIMESTAMP DEFAULT SYSDATE NOT NULL ); ``` 然后,可以使用触发器(Trigger)来在插入数据时生成一个唯一的自增值。以下是一个示例的触发器定义: ``` CREATE SEQUENCE aaa_seq START WITH 1 INCREMENT BY 1; CREATE OR REPLACE TRIGGER aaa_trigger BEFORE INSERT ON aaa FOR EACH ROW BEGIN :NEW.id := aaa_seq.NEXTVAL; END; ``` 这样,每次插入数据时,触发器会自动为id字段生成一个唯一的自增值。 请注意,以上示例只是一种常见的实现方式,具体的实现方式可能会因数据库版本和业务需求而有所差异。建议参考Oracle数据库的官方文档或咨询专业的数据库管理员以获取更准确和详细的信息。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [mybatisplus 自增主键失效自增主键超大](https://blog.csdn.net/w4187402/article/details/127282521)[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^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雾林小妖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值