谢剑雄 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中调用此查询方法即可。

    评论

报告相同问题?

悬赏问题

  • ¥15 mmocr的训练错误,结果全为0
  • ¥15 python的qt5界面
  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀