gpt4 book ai didi

java - 我可以在 JPA 中使用 select from derived tables 吗?

转载 作者:搜寻专家 更新时间:2023-11-01 02:41:06 25 4
gpt4 key购买 nike

我有一个表“asset”,它与一个名为“asset_properties”的表具有 1 对 n 的关系,该表包含该 Assets 的属性列表,以及多对多(使用中间表“asset_has_tag”)关系包含标签列表的“标签”表。

我需要获取一个 Assets 列表,其中包含一些特定标签和一些属性值。

如果我需要具有某些标签或某些属性的 Assets ,我可以简单地将以下 jpa 查询的两个结果添加到 java.util.Set。

我可以使用以下查询通过 native SQL 获得我想要的内容。


原生 SQL 查询:

SELECT a.*
FROM (SELECT ap.*
FROM asset ap JOIN asset_property p
WHERE p.value LIKE "%asd%" OR ap.name LIKE "%asd%" OR ap.description LIKE "%asd%"
) a
JOIN asset_has_tag r, tag h
WHERE a.uuid = r.asset_id AND h.uuid=r.tag_id AND h.category IN ("asd", "qwe", "zxc")
GROUP BY a.uuid

JPA 查询:

String findByAssetAndTagValues =
"select distinct(a) from Asset a join a.Tags h where a.name like :assetname or a.description like :assetdescription and h.name in :tagnames and h.category in :tagcategories and h.uuid=:taguuids"

String findAssetsWithPropertyByValue =
"select distinct(a) from Asset a join a.assetProperties p where p.value like :value"

实体(空的构造函数、移除的 getter 和 setter)

@Entity
public class Asset implements Serializable {
private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(generator = "myUUID")
@GenericGenerator(name="myUUID", strategy="uuid2")
@Column(unique = true, nullable = false, length = 16)
private UUID uuid;

private String description;

// bi-directional many-to-one association to assetProperty
@OneToMany(mappedBy = "asset", fetch = FetchType.LAZY)
private List<AssetProperty> assetProperties;

// bi-directional many-to-many association to tag
@ManyToMany(mappedBy = "assets", fetch = FetchType.LAZY)
private Set<tag> tags;

@Override
public boolean equals(Object obj) {
return (obj != null && obj instanceof Asset && ((Asset)obj).getUuid().equals(uuid));
}
}

@Entity
public class AssetProperty implements Serializable {
private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(unique=true, nullable=false)
private int id;

@Column(nullable=false, length=255)
private String name;

@Column(length=512)
private String value;

//bi-directional many-to-one association to Asset
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="asset_id", nullable=false)
private Asset asset;
}

@Entity
@Table(name = "hardtag")
public class Hardtag implements Serializable {
private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(generator = "uuid")
@GenericGenerator(name = "uuid", strategy = "uuid2")
@Column(unique = true, nullable = false)
private UUID uuid;

@Column(length = 255)
private String category;

@Column(nullable = false, length = 255)
private String name;

// bi-directional many-to-many association to Asset
@ManyToMany(fetch = FetchType.LAZY)
@JoinTable(name = "asset_has_tag", joinColumns = { @JoinColumn(name = "tag_id", nullable = false) }, inverseJoinColumns = { @JoinColumn(name = "asset_id", nullable = false) })
private Set<Asset> assets;

@Override
public boolean equals(Object obj) {
return obj instanceof Hardtag && ((Hardtag) obj).getUuid().equals(uuid);
}
}

编辑:由于 JPA 尚不支持,还有其他选择吗?

最佳答案

JPA 当前不支持从派生表中选择(或在 FROM 子句中包含子查询) .

关于java - 我可以在 JPA 中使用 select from derived tables 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33038595/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com