jpa的@ManyToOne和@OneToMany的使用

一个Strategy可以包含多条StrategyItem, 但一个StrategyItem只能对应一个Strategy。

数据库的结构如:

strategy:

关联表strategy_strategy_item:

strategy_item:

类定义如:

Strategy:

package com.zk.model;

import io.swagger.annotations.ApiModelProperty;
import org.hibernate.annotations.Proxy;

import javax.persistence.*;
import java.util.Date;
import java.util.List;
import java.util.Set;

@Entity
@Table(name = "strategy")
@Proxy(lazy = false)
public class Strategy {
    private Integer id;
   
    //
    // fields definition
    //

    private Set<StrategyItem> strategyItems;

    @Column(name = "id")
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    public Integer getId() {
        return id;
    }

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

    //
    // fields getter and setter
    //

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
    @JoinTable(name="strategy_strategy_item",
            joinColumns=@JoinColumn(name="strategyId", referencedColumnName="id"),
            inverseJoinColumns=@JoinColumn(name="strategyItemId", referencedColumnName="id"))
    public Set<StrategyItem> getStrategyItems() {
        return strategyItems;
    }

    public void setStrategyItems(Set<StrategyItem> strategyItems) {
        this.strategyItems = strategyItems;
    }
}

主要理解:

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
    @JoinTable(name="strategy_strategy_item",
            joinColumns=@JoinColumn(name="strategyId", referencedColumnName="id"),
            inverseJoinColumns=@JoinColumn(name="strategyItemId", referencedColumnName="id"))
    public Set<StrategyItem> getStrategyItems() {
        return strategyItems;
    }

 

StrategyItem:

package com.zk.model;

import javax.persistence.*;

@Entity
@Table(name = "strategy_item")
public class StrategyItem {
    private int id;
    
    //
    // fields definition
    //

    private Strategy strategy;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    public int getId() {
        return id;
    }

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

    // fields getter and setter

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinTable(name="strategy_strategy_item",
            joinColumns=@JoinColumn(name="strategyItemId", referencedColumnName="id"),
            inverseJoinColumns=@JoinColumn(name="strategyId", referencedColumnName="id"))
    public Strategy getStrategy() {
        return strategy;
    }

    public void setStrategy(Strategy strategy) {
        this.strategy = strategy;
    }
}

主要理解:

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinTable(name="strategy_strategy_item",
            joinColumns=@JoinColumn(name="strategyItemId", referencedColumnName="id"),
            inverseJoinColumns=@JoinColumn(name="strategyId", referencedColumnName="id"))
    public Strategy getStrategy() {
        return strategy;
    }

注意: @ManyToOne和@OneToMany并非一定要成对使用,它们用于修饰一个字段,这个例子中的Strategy和StrategyItem的关系平等。

测试用例如:

@RunWith(SpringRunner.class)
@SpringBootTest
public class StrategyServiceImplTest {

    @Autowired
    private StrategyRepository strategyRepository;

    @Autowired
    private StrategyItemRepository strategyItemRepository;

    @Test
    public void testSaveStrategyItem() {
        StrategyItem strategyItem1 = new StrategyItem();
        strategyItem1.setPrice("策略价格1");

        StrategyItem strategyItem2 = new StrategyItem();
        strategyItem2.setPrice("策略价格2");

        Set<StrategyItem> strategyItems = new HashSet<>();
        strategyItems.add(strategyItem1);
        strategyItems.add(strategyItem2);

        Strategy strategy = new Strategy();
        strategy.setStrategyItems(strategyItems);
        Strategy savedStrategy = strategyRepository.save(strategy);

        System.out.println(JSON.toJSONString(savedStrategy));

    }

    @Test
    public void testGetStrategyItem() {
        Optional<StrategyItem> strategyItemOptional = strategyItemRepository.findById(5);
        if(strategyItemOptional.isPresent()) {
            System.out.println(JSON.toJSONString(strategyItemOptional.get()));
        }
    }

    @Test
    public void testUpdateStrategy() {
        Optional<Strategy> strategyOptional = strategyRepository.findById(28);

        if(strategyOptional.isPresent()) {
            Strategy strategy = strategyOptional.get();
            Set<StrategyItem> strategyItems = strategy.getStrategyItems();
            strategyItems.remove(strategyItems.iterator().next());
            strategy.setStrategyItems(strategyItems);
            strategyRepository.save(strategy);
        }
    }
} 

PS:JPA的修饰要么都放在字段定义上,要么都放在get方法上,混合使用将会报错

转载于:https://my.oschina.net/u/4042451/blog/3095693

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值