![](/img/trans.png)
[英]How to create a new SQL row and add elements to its list field in SpringBoot?
[英]How to add frequency of elements from List in SpringBoot?
这是我的实体类,我试图将元素的频率显示为数量,但每次我得到 1 作为数量
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int productid;
private String productname;
private String purchaseamount;
@Transient
private int quantity;
在这里,我试图根据 productId 元素的频率获取数量,但对于每个产品,我只得到 1 个
public List<AddingProductForView> getData(List<Integer> productid) {
List<AddingProductForView> findAllByProductIdIn = repository.findAllByproductidIn(productid);
for (int i = 0; i < findAllByProductIdIn.size(); i++) {
Set<Integer> distinct = new HashSet<>(productid);
for (Integer count : distinct) {
int frequency = Collections.frequency(productid, count);
findAllByProductIdIn.get(i).setQuantity(frequency);
}
}
return findAllByProductIdIn;
}
请求正文:- [1,1,1,1,2,2]
[
{
"productid": 1,
"productname": "RO",
"purchaseamount": "4000 ",
"quantity": 1
},
{
"productid": 2,
"productname": "RO",
"purchaseamount": "8000 ",
"quantity": 1
}
]
预期结果:-
[
{
"productid": 1,
"productname": "RO",
"purchaseamount": "4000 ",
"quantity": 4
},
{
"productid": 2,
"productname": "RO",
"purchaseamount": "8000 ",
"quantity": 2
}
]
我能理解你的意图。
我尝试将此代码用于我的开发环境。 它运作良好。
我建议一些方法
1.你最好调试一下
// whether frequency is exist or not.
int frequency = Collections.frequency(productid, count);
2.你真的要这样吗? 如果此代码执行,频率的结果是集合的最终实体。因为您不使用 if 条件。
for (int i = 0; i < findAllByProductIdIn.size(); i++) {
//distinct = [1,2]
Set<Integer> distinct = new HashSet<>(productid);
/** frequency is unconditionally 2. */
for (Integer count : distinct) {
int frequency = Collections.frequency(productid, count);
findAllByProductIdIn.get(i).setQuantity(frequency);
}
}
我可以检查频率和 getQuantity。 我建议调试。
如果有条件,你是必要的
loop : for (int i = 0; i < findAllByProductIdIn.size(); i++) {
Set<Integer> distinct = new HashSet<>(productid);
for (Integer count : distinct) {
if(findAllByProductIdIn.get(i).getProductId == count) {
int frequency = Collections.frequency(productid, count);
findAllByProductIdIn.get(i).setQuantity(frequency);
continue loop;
}
}
}
我修改了你的代码。 如果条件允许,这不是必需的,并且可以减少代码行
for (int i = 0; i < findAllByProductIdIn.size(); i++) {
int frequency = Collections.frequency(productid,findAllByProductIdIn.get(i).getProductId);
findAllByProductIdIn.get(i).setQuantity(frequency);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.