关于springboot jpa 默认使用hibernate_sequences序列自增的问题

spring-boot-starter-data-jpa

        spring-boot-starter-data-jpa默认采用hibernate实现方式,这对于我们的单表操作,以及ORM逆向工程使用起来都特变方便,但是我们在通过实体类逆向生成数据库表的时候,可能会存在一点问题。

hibernate实体类逆向生成数据库表的问题

问题描述

        当我在完成配置,建立好相关实体类,启动工程后我发现。hibernate除了为我们创建了实体类对应的数据库表还自动新建了hibernate_sequences表。

package com.itxiaoyuaiit.learnspringboot.model;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import java.util.Date;

/**
 * @ClassName User
 * @Description user实体
 * @Author wuyuqing
 * @Date 2020/8/23 20:04
 * @Version 1.0
 */
@Entity
@Table(name = "user")    //不指定name=user,默认创建的表名也是user
public class User {

    @Id
    @GeneratedValue    
    private Integer id;

    private String name;

    private Integer age;

    private String job;

    private Date birthday;

    public User() {
    }

    public User(Integer id, String name, Integer age, String job, Date birthday) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.job = job;
        this.birthday = birthday;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getJob() {
        return job;
    }

    public void setJob(String job) {
        this.job = job;
    }

    public Date getBirthday() {
        return birthday;
    }

    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    }
}

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/*****?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT
    username: root
    password: ******
  jpa:
    hibernate:
      ddl-auto: create
    show-sql: true

问题分析

        打开@GeneratedValue源码会发现,该注解默认的属性值为strategy = GenerationType.AUTO,当我们在实体类Id字段中使用@GeneratedValue默认值实现主键自增时,hibernate在为我们创建实体表的同时,也会为我们创建一张hibernate_sequences序列表。
        要想使用数据库引擎内部的自增机制,必须强制指定strategy = GenerationType.IDENTITY。
        strategy的值可以为如下四种。

AUTO 主键由程序控制, 默认值

IDENTITY 主键由数据库生成, 采用数据库自增长, Oracle不支持这种方式
 
SEQUENCE 通过数据库的序列产生主键, MYSQL不支持
 
Table 提供特定的数据库产生主键, 该方式更有利于数据库的移植

问题处理

        要想使用mysql内部的自增机制,我们只需指定@GeneratedValue(strategy = GenerationType.IDENTITY) 即可。当strategy = GenerationType.IDENTITY的时候hibernate在执行建表的时候,就会采用数据库内部的自增机制。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值