Mysql 在JPA中更新而不使用本机查询
我有一个实体类Mysql 在JPA中更新而不使用本机查询,mysql,hibernate,jpa,spring-boot,Mysql,Hibernate,Jpa,Spring Boot,我有一个实体类 @Data @Entity @Table("invite_data") public class InvitationData { @Id @GeneratedValue( strategy = GenerationType.AUTO ) @Column( name = "rl_id" ) private Long id; @Column( name = "rl_invitee_email" ) private String inviteeEmailId; @Column(
@Data
@Entity
@Table("invite_data")
public class InvitationData {
@Id
@GeneratedValue( strategy = GenerationType.AUTO )
@Column( name = "rl_id" )
private Long id;
@Column( name = "rl_invitee_email" )
private String inviteeEmailId;
@Column( name = "rl_generated_link" )
private String generatedLink;
@Column( name = "rl_expire_at" )
private Calendar expiresAt;
@Column( name = "rl_generated_code" )
private String generatedCode;
@Column( name = "rl_created_at" )
private Calendar invitedAt;
@ManyToOne( fetch = FetchType.EAGER )
@JoinColumn( name = "rl_frn_created_by", referencedColumnName = "u_id" )
private UserModel invitedBy;
@Column( name = "rl_is_active" )
private Boolean isActive;
@Column( name = "rl_is_used" )
private Boolean isUsed;
@ManyToOne( fetch = FetchType.EAGER )
@JoinColumn( name = "rl_frn_invited_role", referencedColumnName = "as_id" )
private AccountStatus invitedRole;
}
我无法执行更新查询
public interface InvitationRepository extends JpaRepository<InvitationData, Long> {
@Modifying( clearAutomatically = true )
@Query( "UPDATE InvitationData invite SET invite.isActive = false WHERE invite.id= :invitationId AND invite.isUsed = false AND"
+ " invite.isActive = true AND invite.expiresAt >=:now AND i.invitedBy =:user" )
Integer cancelInvitation( @Param( "invitationId" ) Long id, @Param( "now" ) Calendar now,
@Param( "user" ) UserModel user );
可能是什么问题?如果实体类中有外键,我可以直接将实体类作为参数传递,还是执行联接?您的查询不正确 这个
i.invitedBy =:user
一定是
invite.invitedBy =:user
真不敢相信我犯了这么愚蠢的错误。谢谢你的帮助。很抱歉在未正确验证的情况下发布问题
invite.invitedBy =:user