71

我想写一个类似的查询SELECT * FROM Release_date_type a LEFT JOIN cache_media b on a.id=b.id。我是 Spring Data JPA 的新手。我不知道如何为 Join 查询编写实体。这是一个尝试:

@Entity
@Table(name = "Release_date_type")
public class ReleaseDateType {

    @Id
    @GeneratedValue(strategy=GenerationType.TABLE)
    private Integer release_date_type_id;
    // ...
    @Column(nullable = true) 
    private Integer media_Id;
    // with getters and setters...
}

另一个实体是:

@Entity
@Table(name = "Cache_Media")
public class CacheMedia {

    @Id
    @GeneratedValue(strategy=GenerationType.TABLE)
    private Integer id;
    // ...
    private Date loadDate; //with the getter and setter ..
}

我想写一个crudRepository接口,比如

public interface ReleaseDateTypeRepository extends CrudRepository<ReleaseDateType, Long>{
    @Query("SELECT * FROM Release_date_type a LEFT JOIN cache_media b on a.id=b.id")
    public List<ReleaseDateType> FindAllWithDescriptionQuery();
}
4

3 回答 3

107

有关拥有一部或多部手机的员工的典型示例,请参阅此 wikibook 部分

对于您的具体示例,如果您想建立one-to-one关系,您应该更改 ReleaseDateType 模型中的下一个代码:

@Column(nullable = true) 
private Integer media_Id;

为了:

@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name="CACHE_MEDIA_ID", nullable=true)
private CacheMedia cacheMedia ;

在 CacheMedia 模型中,您需要添加:

@OneToOne(cascade=ALL, mappedBy="ReleaseDateType")
private ReleaseDateType releaseDateType;

然后在您的存储库中,您应该替换:

@Query("Select * from A a  left join B b on a.id=b.id")
public List<ReleaseDateType> FindAllWithDescriptionQuery();

经过:

//In this case a query annotation is not need since spring constructs the query from the method name
public List<ReleaseDateType> findByCacheMedia_Id(Integer id); 

或通过:

@Query("FROM ReleaseDateType AS rdt WHERE cm.rdt.cacheMedia.id = ?1")    //This is using a named query method
public List<ReleaseDateType> FindAllWithDescriptionQuery(Integer id);

或者,如果您更喜欢做一个@OneToMany@ManyToOne关系,您应该更改 ReleaseDateType 模型中的下一个代码:

@Column(nullable = true) 
private Integer media_Id;

为了:

@OneToMany(cascade=ALL, mappedBy="ReleaseDateType")
private List<CacheMedia> cacheMedias ;

在 CacheMedia 模型中,您需要添加:

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="RELEASE_DATE_TYPE_ID", nullable=true)
private ReleaseDateType releaseDateType;

然后在您的存储库中,您应该替换:

@Query("Select * from A a  left join B b on a.id=b.id")
public List<ReleaseDateType> FindAllWithDescriptionQuery();

经过:

//In this case a query annotation is not need since spring constructs the query from the method name
public List<ReleaseDateType> findByCacheMedias_Id(Integer id); 

或通过:

@Query("FROM ReleaseDateType AS rdt LEFT JOIN rdt.cacheMedias AS cm WHERE cm.id = ?1")    //This is using a named query method
public List<ReleaseDateType> FindAllWithDescriptionQuery(Integer id);
于 2014-03-10T17:55:08.447 回答
1
@Query("SELECT rd FROM ReleaseDateType rd, CacheMedia cm WHERE ...")
于 2020-04-15T00:50:31.807 回答
-4

这是一个古老的问题,但解决方案非常简单。如果您不确定如何在 hibernate 中编写条件、连接等,那么最好的方法是使用本机查询。这不会降低性能并且非常有用。方程。以下

    @Query(nativeQuery = true, value = "your sql query")
returnTypeOfMethod methodName(arg1, arg2);
于 2020-04-15T03:30:22.117 回答