当前位置: 首页 > 知识库问答 >
问题:

通过@EmbeddedId的“查询创建”方法构建Spring Data JPA查询

骆雅昶
2023-03-14

我很难找到任何类型的文档,说明如何在我的模型中查询更复杂的属性。

public class MyEmbedded{
@EmbeddedID
private MyEmbeddedPK embeddedPK;
}

@Embeddable
public class MyEmbeddedPK{

     private Integer age;

     private Integer zip;       
}
public List<MyEmbedded> findByageAndZip(String age, String zip);

关于这个查询创建是如何工作的,有没有更好的文档?

共有1个答案

养学
2023-03-14

我不确定Spring Data Jpa是否支持此功能,而且基于嵌入式id属性的查询似乎有点复杂,因为它同样适用于封闭实体本身的状态字段。但这可以通过JP QL轻松实现,方法是使用Query和@param指定它

@Query("SELECT m FROM MyEmbedded m WHERE m.embeddedPK.age = :age AND m.embeddedPK.zip = :zip")
public List<MyEmbedded> findByageAndZip(@Param("age") String age, @Param("zip") String zip);

另外,不要忘记使用以下签名指定存储库,因为Spring data运行时需要知道ID类的实际类型。

@Repository
public interface MyEmbeddedRepository extends CrudRepository<MyEmbedded, MyEmbeddedPK> {..}
 类似资料:
  • 基础Spring Data repository内置的查询生成器机制对于创建实体仓库的约束查询是有用的,它会从方法名中去掉find…By,read…By,query…By,count…By和get…By这些前缀并解析剩下的内容.这些前缀还能包含更多的表达式例如Distinct,设置一个distinct标志并在查询中创建它,然后第一个By的动作就像一个分隔符来表明查询实际标准的开始。最基本的方式你可

  • 问题内容: 我需要在通过JPA EntityManager访问的数据库中创建一个新表。JPA NativeQueries是否支持“选择”或“更新”以外的查询?还是在JPA上下文中还有另一种先进的方法来执行复杂的SQL查询? 问题答案: jpa“本机查询”仅可用于DML语句(数据处理语言)。要发布任何DDL(例如创建表),您需要从EntityManager获取基础连接。 如何从EM中提取连接将取决于

  • 查询构建器建立在 Database Access Objects 基础之上,可让你创建 程序化的、DBMS无关的SQL语句。相比于原生的SQL语句,查询构建器可以帮你 写出可读性更强的SQL相关的代码,并生成安全性更强的SQL语句。 使用查询构建器通常包含以下两个步骤: 创建一个 yii\db\Query 对象来代表一条 SELECT SQL 语句的不同子句(例如 SELECT, FROM)。 执

  • 我使用GraphDB存储库,希望通过Java使用SPARQLRepository执行一些查询。当我阅读这些问题时,它工作得很好。但当我有一个查询“creategraph:example”或一个insert-and-delete查询时,它就不起作用了。当我通过GraphDB UI执行查询时,它运行良好。SPARQLRepository的doku说,我需要第二个endpoint,根据GraphDB d

  • 以下示例将演示如何在DBUtils的帮助下,使用语句来创建记录。 我们将在表中插入一条记录。 语法 其中, insertQuery − Insert query having placeholders. queryRunner − QueryRunner object to insert employee object in database. 为了理解上述与DBUtils相关的概念,我们编写一个

  • 主要内容:创建一个更新查询,创建一个删除查询,创建一个建表查询在本章中让我们来了解如何创建查询。 创建一个更新查询 可以使用更新查询更改表中的数据,并且可以使用更新查询来输入条件以指定应更新哪些行。 在执行更新之前,更新查询提供了一个查看更新数据的机会。 让我们再次转到“创建”选项卡,然后单击“查询设计”。 在“表”选项卡的“显示表”对话框中,双击表,然后关闭对话框。 在“设计”选项卡的“查询类型”组中,单击“更新”并双击要更新值的字段。假设要将员工编号为: