谢剑雄 2019-11-14 16:57 采纳率: 0%
浏览 280

组合唯一键如何使用jpa查询出单条记录?

图片说明图片说明图片说明

这种写法好像行不通,不知有没有大神有更好的建议?

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 05:03
    关注

    对于这种情况,可以使用JPA的@EmbeddedId注解来定义唯一键的实体类,然后在对应的Repository中使用@NamedQuery或者@Query注解来写自定义查询语句,以查询单条记录。具体实现步骤如下:

    1. 定义唯一键的实体类,使用@EmbeddedId注解来指定:
    @Embeddable
    public class UniqueKey implements Serializable {
      private static final long serialVersionUID = 1L;
      
      @Column(name = "id1")
      private Long id1;
      
      @Column(name = "id2")
      private Long id2;
      
      // setter and getter methods...
    }
    
    1. 在实体类中引入唯一键,并添加@EmbeddedId注解:
    @Entity
    @Table(name = "mytable")
    public class MyEntity {
    
      @EmbeddedId
      private UniqueKey uniqueKey;
    
      // other columns...
    
      // setter and getter methods...
    }
    
    1. 在Repository中定义自定义查询语句,使用@NamedQuery或者@Query注解来指定:
    @Repository
    public interface MyRepository extends JpaRepository<MyEntity, UniqueKey> {
    
      @Query("SELECT m FROM MyEntity m WHERE m.uniqueKey.id1 = ?1 AND m.uniqueKey.id2 = ?2")
      MyEntity findByUniqueKey(Long id1, Long id2);
    
      // other custom queries...
    }
    

    然后在Service中调用此查询方法即可。

    评论

报告相同问题?

悬赏问题

  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题