首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SpringDataJPA @ManyToMany crud

SpringDataJPA @ManyToMany crud
EN

Stack Overflow用户
提问于 2020-06-04 15:56:00
回答 1查看 67关注 0票数 0

我想插入一件货物。

数据库中已经有或没有某些类别。

我见过许多类似的问题和解决方案,看上去像CascadeType

其实我不明白。

这里有两门课和考试

代码语言:javascript
复制
@Entity
@Table(name = "t_goods")
@Data
public class Goods implements Serializable {
    private static final long serialVersionUID = -7781710173608724249L;
    @Id
    @GenericGenerator(name = "goodsid",strategy = "uuid")
    @GeneratedValue(generator = "goodsid")
    private String goodsId;

    private String goodsName;

    @ManyToMany(cascade = {CascadeType.PERSIST})
    private Set<GoodsCate> goodsCateSet;
}
代码语言:javascript
复制
@Entity
@Table(name = "t_category",uniqueConstraints = { @UniqueConstraint(columnNames = "cateName")})
@Getter
@Setter
public class GoodsCate implements Serializable {
    private static final long serialVersionUID = -8990216455436375344L;
    @Id
    @GenericGenerator(name = "goodscateid",strategy = "uuid")
    @GeneratedValue(generator = "goodscateid")
    private String cateId;

    private String cateName;

   @ManyToMany(mappedBy = "goodsCateSet")
   private Set<Goods> goods;
}
代码语言:javascript
复制
@Test
void test(){

    Goods goods = new Goods();
    goods.setGoodsName("apple");

    GoodsCate food = new GoodsCate();
    food.setCateName("food");
    GoodsCate fooddb= goodsCateRepo.findGoodsCateByCateName(food.getCateName());
    if(fooddb!=null){
        food=fooddb;
    }
    GoodsCate vegetable= new GoodsCate();
    vegetable.setCateName("vegetable");
    GoodsCate vegetabledb = goodsCateRepo.findGoodsCateByCateName(vegetable.getCateName());
    if(vegetabledb!=null){
        vegetable = vegetabledb;
    }
    Set<GoodsCate> goodsCates = Sets.newSet(food, vegetable);


     goods.set(goodsCates);
     // goodsRepo is a interface extends jpaReposity
     goodsRepo.save(goods);

}

它抛出

传递给org.springframework.dao.InvalidDataAccessApiUsageException:的persist:com.xx.xxx.GoodsCate分离实体

EN

回答 1

Stack Overflow用户

发布于 2020-06-04 16:45:30

看起来你还没有把你的分类和商品联系起来。

我建议添加两个实用方法(例如,商品中的addCategory(Category category)和类别中的addGood(Goods good) ),它们用于同步双向关联的双方。当您使用双向关联时,应该始终提供这些方法,否则,您将面临非常微妙的状态传播问题。

Goods

代码语言:javascript
复制
public void addCategory(Category category) {
        categories.add(category);
        category.getGoods().add(this);
    }

Category

代码语言:javascript
复制
public void addGood(Good good) {
        goods.add(good);
        good.getCategory().add(this);
    }

Note:还不要忘记添加remove实用程序,就像上面的一样。

然后您可以使用下面的代码

代码语言:javascript
复制
@Test
    void test(){

        Goods goods = new Goods();
        goods.setGoodsName("apple");

        GoodsCate food = new GoodsCate();
        food.setCateName("food");
        GoodsCate fooddb= goodsCateRepo.findGoodsCateByCateName(food.getCateName());
        if(fooddb!=null){
            food=fooddb;
        }
        GoodsCate vegetable= new GoodsCate();
        vegetable.setCateName("vegetable");
        GoodsCate vegetabledb = goodsCateRepo.findGoodsCateByCateName(vegetable.getCateName());
        if(vegetabledb!=null){
            vegetable = vegetabledb;
        } 
        //********After adding mentioned utilites********    
         goods.addCategory(food);
         goods.addCategory(vegetable);
         // goodsRepo is a interface extends jpaReposity
         goodsRepo.save(goods);

    }

多到多个最佳实践的文章之一

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62198996

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档