【发布时间】:2020-01-15 22:10:37
【问题描述】:
我有两个实体并使用多对一注释映射了这些实体,但是在使用另一个表 id 编写查找对象的查询后,当我注释掉该应用程序调用的行和方法时出现错误,但我想实现该功能,请帮助我
这些是我的实体类:
@Entity
@Table(name = "Contract")
public class Contract implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "contractId")
private long contractId;
@Column(name="start_date")
private Date st_date;
@Column(name="end_date")
private Date end_date;
@ManyToOne(fetch = FetchType.LAZY, optional = false)
@JoinColumn(name = "hotel_id", nullable = false)
@OnDelete(action = OnDeleteAction.CASCADE)
@JsonIgnore
private Hotel hotel;
// getters and setters
第二个实体
@Entity
@Table(name="Hotel")
public class Hotel {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name="hotel_id")
private long hotel_id;
@Column(name="hotel_name")
private String hotel_name;
@Column(name="hotel_location")
private String hotel_location;
@Column(name="hotel_email")
private String hotel_email;
@Column(name="hotel_telephone")
private String hotel_telephone
// getters and setters
我的合同服务类
@Service
public class ContractService {
@Autowired
private ContractRepository contractRepository;
@Autowired
private HotelRepository hotelRepository;
public List<Contract> getAllContracts(){
return contractRepository.findAll();
}
public List<Contract> findByHotelId(Long hotelId,Pageable pageable){
return contractRepository.findByHotelId(hotelId, pageable);
}
public ResponseEntity<?> deleteContract(Long hotelId, Long contractId)
{
return contractRepository.findByIdAndHotelId(contractId,
hotelId).map(Contract -> {
contractRepository.delete(Contract);
return ResponseEntity.ok().build();
}).orElseThrow(() -> new ResourceNotFoundException("Comment not found
with ContractId " + contractId + " and hotelId " + hotelId));
}
我的合约仓库
@Repository
public interface ContractRepository extends JpaRepository<Contract, Long> {
List<Contract> findByHotelId(Long hotelId, Pageable pageable);
Optional<Contract> findByIdAndHotelId(Long id, Long hotelId);
}
我在运行我的项目时遇到了这个错误
org.springframework.beans.factory.UnsatisfiedDependencyException: 创建名为“contractController”的 bean 时出错:通过字段“contractService”表示的依赖关系不满足;嵌套异常是 org.springframework.beans.factory.UnsatisfiedDependencyException:创建名称为“contractService”的 bean 时出错:通过字段“contractRepository”表示的依赖关系不满足;嵌套异常是 org.springframework.beans.factory.BeanCreationException:创建名为“contractRepository”的 bean 时出错:调用 init 方法失败;嵌套异常是 java.lang.IllegalArgumentException: 无法为方法 public abstract java.util.List com.sunTravel.sunRest.repository.ContractRepository.findByHotelId(java.lang.Long,org.springframework.data.domain.Pageable) 创建查询!未找到类型酒店的属性 ID!遍历路径:Contract.hotel。
【问题讨论】:
标签: spring rest spring-boot jpa spring-data-jpa