だから私は4つのテーブルを持っています
雇用主
@Entity
@EqualsAndHashCode(callSuper = false)
@Table(name = "employers")
@NoArgsConstructor
@AllArgsConstructor
@JsonIgnoreProperties({"hibernateLazyInitializer", "handler", "jobPostings"})
@PrimaryKeyJoinColumn(name="employer_id", referencedColumnName = "id")
public class Employer extends User {
@Column(name = "company_name")
private String companyName;
@Column(name = "website")
private String website;
@Column(name = "phone_number")
private String phoneNumber;
@OneToMany(mappedBy="employer")
private List<JobPosting> jobPostings;
}
街
@Data
@Entity
@Table(name="cities")
@AllArgsConstructor
@NoArgsConstructor
@JsonIgnoreProperties({"hibernateLazyInitializer", "handler", "jobPostings"})
public class City {
@Id
@Column(name="id")
private int id;
@Column(name="city_name")
private String cityName;
@OneToMany(mappedBy="city")
private List<JobPosting> jobPostings;
}
役職
@AllArgsConstructor
@Data
@Entity
@Table(name="job_positions")
@JsonIgnoreProperties({"hibernateLazyInitializer", "handler", "jobPostings"})
public class JobPosition {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name="job_position_id")
private int id;
@Column(name="title")
private String title;
@OneToMany(mappedBy="jobPosition")
private List<JobPosting> jobPostings;
}
And A JobPosting(求人広告のようなもの)
@Entity
@Table(name="job_postings")
@Data
@NoArgsConstructor
@AllArgsConstructor
//@JsonIgnoreProperties({"hibernateLazyInitializer", "handler", "city", "jobPosition","employer"})
public class JobPosting {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="id")
private int id;
@Column(name="job_requirements")
private String jobRequirements;
@Column(name="salary_min")
private int salaryMin;
@Column(name="salary_max")
private int salaryMax;
@Column(name="application_deadline")
private LocalDate applicationDeadline;
@Column(name="number_of_openings")
private int numberOfOpenings;
@Column(name="stream_date")
private LocalDate streamDate;
@ManyToOne()
@JoinColumn(name="city_id")
private City city;
@ManyToOne()
@JoinColumn(name="job_position_id")
private JobPosition jobPosition;
@ManyToOne()
@JoinColumn(name= "employer_id")
private Employer employer;
}
それらすべてに必要なマッピングを実装しましたが、正常に機能しています。ただし、次のような DTO でそれらに参加したい:
@Data
@AllArgsConstructor
@NoArgsConstructor
public class JobPostingWithJobPositionCityEmployerDto {
private int id;
private String jobRequirements;
private int salaryMin;
private int salaryMax;
private LocalDate applicationDeadline;
private int numberOfOpenings;
private LocalDate streamDate;
private String cityName;
private String title;
private String companyName;
}
よりクリーンな方法で必要なフィールドを取得するために、springframework.jpa の @Query アノテーションを使用しようとしていますが、これについて学んだばかりなので、うまく管理できません。使用しているクエリは次のとおりです。
@Query(value ="Select new kodlamaio.hrms.entities.dtos.JobPostingWithJobPositionCityEmployerDto"
+ "(j.id, j.jobRequirements, j.salaryMin, j.salaryMax, j.numberOfOpenings, j.streamDate, j.applicationDeadline, c.cityName, p.title, e.companyName)"
+ " From Employer e Inner Join e.jobPostings j, "
+ "From City c Inner Join c.jobPostings j, "
+ "From JobPosition p Inner Join p.jobPostings j", nativeQuery = true)
List<JobPostingWithJobPositionCityEmployerDto> getJobPostings();
これが正しい方法であるかどうかさえわかりません。構文エラーが発生し続け、回答を調べましたが、彼らが何を言っているのかを完全に理解できませんでした。さまざまなシナリオがありました。したがって、誰かがこのクエリを手伝ってくれて、さまざまなコマンドについて学ぶためにいくつかの情報源を推奨してくれたら、とても感謝しています。よろしくお願いします。