【发布时间】:2021-04-12 14:22:21
【问题描述】:
我正在尝试在 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 填充在使用响应式和非响应式存储库查询的对象中,它的外观如下在广告系列中
@JoinColumn(name = "customer_id", referencedColumnName = "customer_id")
@ManyToOne(optional = false)
public Customer getCustomer() {
return customer;
}
public void setCustomer(Customer customer) {
this.customer = customer;
}
【问题讨论】:
-
您能否在实际调用
Repository的位置添加调用部分?id是唯一缺少的属性还是没有显示任何其他属性? -
用更多信息编辑了原始帖子。
标签: java reactive-programming micronaut micronaut-data