1

たとえば、Userエンティティ:

@Configurable
@Entity
@Data
@EqualsAndHashCode(callSuper = false)
@DynamicInsert
@DynamicUpdate
public class User extends AbstractAggregateRoot<User> implements Serializable {

    private static final long serialVersionUID = 1L;

    @Autowired
    @Transient
    private UserRepository userRepository;

    @Autowired
    @Transient
    private EmailRepository emailRepository;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String nickname;

    @Version
    @Column(columnDefinition = "timestamp")
    @Source(value = SourceType.DB)
    private Timestamp ts;

    public void doSavedComplete() {
        UserSavedEvent event = new UserSavedEvent();
        event.setUser(this);
        event.setTs(new Date());
        andEvent(event);
        userRepository.save(this);
    }

    @Data
    public static class UserSavedEvent {
        private User user;
        private Date ts;
    }
}

そしてそれはリポジトリです:

@Repository
public interface UserRepository extends JpaRepository<User, Long> {

}

新しいUserオブジェクトを作成するとき:

User ob = new User();

ユーザーのuserRepositoryemailRepositorynullです。Userと にEmailはそれぞれRepositoryのクラスがUserRepositoryあり、EmailRepository;

UserAggregateRootSpring Data JPA リポジトリを持たない別のクラスを使用すると、ロード時間の織り方がうまく機能します。

@Configurable
@Entity
public class UserAggregateRoot extends AbstractAggregateRoot<User> implements Serializable {
    @Autowired
    @Transient
    private UserRepository userRepository;

    @Autowired
    @Transient
    private EmailRepository emailRepository;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String nickname;

    @Version
    @Column(columnDefinition = "timestamp")
    @Source(value = SourceType.DB)
    private Timestamp ts;
}

UserAggregateRootがないRepositoryので、新しいUserAggregateRootオブジェクトを作成すると、 と のフィールドはUserAggregateRootではUserRepositoryありEmailRepositoryませんnull

だから私は理由を知りたいですか?バグですか?

4

0 に答える 0