我正在尝试在 Micronaut 中实现一个反应式(r2dbc)存储库,但我遇到了一些正在查询的数据问题。使用非反应性存储库时不会出现这些问题。这是我的反应式存储库的外观:
@R2dbcRepository(dialect = Dialect.MYSQL)
public interface ReactiveCampaignRepository extends ReactiveStreamsCrudRepository<Campaign, Integer> {
@Override
Flux<Campaign> findAll();
}
这就是我的常规存储库的外观:
@Repository
public interface CampaignRepository extends CrudRepository<Campaign, Integer> {
}
从 ReactiveCampaignRepository 调用 findAll 方法时,我可以查询所有实体,但是它们都有空 id。当我从 CampaignRepository 调用 findAll 时,将查询所有实体并正确填充 Id。
这是 id 字段在 Campaign 中的外观,这是一个远程依赖项
@Entity
@Table(name = "campaign")
public class Campaign implements Serializable {
private static final long serialVersionUID = 1L;
private Integer id;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
这个实体是这样内省的:
@Introspected(classes = {Campaign.class})
public class EntitiesConfiguration {
}
我是 micronaut 和 r2dbc 的新手,所以我可能会遗漏一些明显的东西,但我无法弄清楚,任何指针都将不胜感激。
谢谢你
编辑:
@tmarouane 这只是一个简单的控制器来测试事情是否按预期工作。
@Get(value = "/all")
public Flux<CampaignDTO> allCampaigns() {
return reactiveCampaignRepository.findAll().map(CampaignDTO::new);
}
@Get(value = "/all2")
public List<CampaignDTO> allCampaigns2() {
return StreamSupport.stream(campaignRepository.findAll().spliterator(), false).map(CampaignDTO::new).collect(Collectors.toList());
}
和控制器
@Produces(MediaType.APPLICATION_JSON)
@Secured(SecurityRule.IS_AUTHENTICATED)
@Controller("/campaign")
public class CampaignController {
private final CampaignRepository campaignRepository;
private final ReactiveCampaignRepository reactiveCampaignRepository;
public CampaignController(CampaignRepository campaignRepository,
ReactiveCampaignRepository reactiveCampaignRepository
) {
this.campaignRepository = campaignRepository;
this.reactiveCampaignRepository = reactiveCampaignRepository;
}
CampaignDTO 只是一个简单的 DTO 类,其中只使用了 Campaign 字段的一个子集,其中一个简单的构造函数获取 Campaign 对象。
public CampaignDTO(Campaign campaign) {
this.id = campaign.getId();
}
除了 id 之外,还有 1 个不为空的属性,但它自己的属性为空,我一开始没有发现 - 客户,即使 customer_id 填充在使用反应式和非反应式存储库查询的对象中,这就是它在 Campaign 中的外观
@JoinColumn(name = "customer_id", referencedColumnName = "customer_id")
@ManyToOne(optional = false)
public Customer getCustomer() {
return customer;
}
public void setCustomer(Customer customer) {
this.customer = customer;
}