SpringBoot--调用JpaRepository接口的save方法报错

JPA的两个注解@id和@GeneratedValue

@id  标注用于声明一个实体类的属性映射为数据库的主键列。

@GeneratedValue   用于标注主键的生成策略。(问题就出在这里)

JPA为开发人员提供了四种主键生成策略,被定义在枚举类GenerationType中,包含(TABLE , SEQUENCE , IDENTITY , AUTO).

先介绍下这四种策略:

(1)GenerationType.TABLE

       使用一个特定的数据库表格来保存主键,持久化引擎通过关系数据库的一张特定的表格来生成主键。

       策略的优点:不依赖于外部环境和数据库的具体实现,在不同数据库间可以很容易的进行移植。

       缺点:不能充分利用数据库的特性,一般不会优先使用。

(2)GenerationType.SEQUENCE

        在某些数据库中,不支持主键自增长,比如Oracle,其提供了一种叫做"系列(sequence)"的机制生成主键。

         该策略只要部分数据库(Oracle/PostgreSQL/DB2)支持序列对象,所以该策略一般不应用与其他数据库。

(3)GenerationType.IDENTITY

        此种主键生成策略就是通常所说的主键自增长,数据库在插入数据时,会自动给主键赋值,比如Mysql可以在创建表时声明"auto_increment"来指定主键自增长。大部分数据库都提供了该支持。

(4)GenerationType.AUTO

        把主键生成策略交给持久化引擎,持久化引擎会根据数据库在以上三种主键生成策略中选择其中一种。因为这种策略比较常用,所以JPA默认的生成策略就是AUTO.

 

   我的代码中没有声明,默认的AUTO,这种方式如果数据库中不存在这张表的时候,用它来指定自增方式没有问题,但是如果数据库中已经存在这张表并设计了自动方式,那么插入数据的时候就会报错。

  所以改成了:

@GeneratedValue(strategy = GenerationType.IDENTITY)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Domain Service是领域驱动设计(DDD)中的一个概念,用于处理领域之间的业务逻辑,包含了领域知识和业务规则。而Repository是用于持久化和检索领域对象的接口或类。因此,当Domain Service需要访问数据库或持久化存储时,可以调用Repository来完成相应的操作。 Domainservice调用repository的过程如下: 1. Domainservice首先根据业务需求和逻辑,需要访问或操作Repository中的数据。 2. Domainservice调用Repository接口中定义的方法,传递相应的参数。 3. Repository实现类根据接收到的参数,利用底层的数据库访问机制,完成数据的持久化或检索。 4. Repository将操作结果返回给Domainservice。 5. Domainservice根据Repository返回的结果,进行后续的业务处理。 举个例子来说,假设有一个电子商务系统,有一个CartService(购物车服务)作为Domainservice,而CartRepository(购物车仓储)作为Repository。当用户在购物车中添加商品时,CartService需要将该商品信息保存到数据库中。此时,CartService就会调用CartRepository的addProduct方法,并传递商品信息作为参数。CartRepository的实现类会将商品信息保存到数据库中。然后,CartRepository将保存结果返回给CartService,CartService根据返回结果进行相关的业务处理,例如更新购物车的总价等。 通过使用Repository,Domainservice能够更加专注于领域业务逻辑的实现,将数据操作交给专门的类来处理,提高了代码的模块化和可读性。同时,Repository也提供了一种抽象层,使得更换底层数据库或数据访问机制时,对领域逻辑的影响尽可能的降到最低。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值