Seata 1.5.1配置db和redis模式
https://blog.csdn.net/qhzh123/article/details/130471680
Exception in thread “main” java.lang.NullPointerException
at java.util.HashMap.merge(HashMap.java:1225)
at java.util.stream.Collectors.lambda$toMap$58(Collectors.java:1320)
at java.util.stream.ReduceOps$3ReducingSink.accept(ReduceOps.java:169)
at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1384)
at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:482)
at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:472)
at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499)
at com.ex.demo2.user.Test.main(Test.java:25)
@Data
public class Product {
private Integer id;
private String name;
private String sex;
}
public class Test {
public static void main(String[] args) {
List<Product> products = new ArrayList<Product>();
for (int i = 0; i < 3; i++) {
Product product = new Product();
product.setId(i + 1);
product.setName(String.format("name_%s", i));
product.setSex(i % 2 == 0 ? "MAN" : "WOMAN");
products.add(product);
}
//这里把第二个product的name设为null
products.get(1).setName(null);
Map<Integer, String> collect = products.stream().collect(Collectors.toMap(Product::getId,Product::getName));
System.out.println(collect);
}
这里可以看到如果toMap的value是null的就会报空指针,经过测试 如果id为null也会报空指针
解决这个问题,可以通过filter过滤掉这些null的数据
Map<Integer, String> collect = products.stream()
.filter(k -> k.getId() != null).filter(v -> v.getName() != null)
.collect(Collectors.toMap(Product::getId, Product::getName));
等于:criteriaBuilder.equal
Predicate countryPredicate = criteriaBuilder.equal(root.get(“name”), “小明”);
and 和 or 查询
criteriaBuilder.and(predicates.toArray(Predicate对象,Predicate对象)
criteriaBuilder.or(predicates.toArray(Predicate对象,Predicate对象))
大于:criteriaBuilder.greaterThan
criteriaBuilder.greaterThan(root.get(“name”), 3);
小于:criteriaBuilder.lessThan
大于等于:criteriaBuilder.greaterThanOrEqualTo
小于等于:criteriaBuilder.lessThanOrEqualTo
相似查询:criteriaBuilder.like
Specification spec = (Specification) (root, criteriaQuery, criteriaBuilder) -> {
Predicate p = criteriaBuilder.like(root.get(“name”), “%” + “小明” + “%”);
return p;
};
把某字段第10位设置为1
update tests set uid = uid|(1 << 10) where id=1;
把某个字段第10位设置为0
update tests set uid = uid&~(1 << 10) where id=1;
/**
* 判断字符串是否为数字
*
* @param str String
* @return Boolean
*/
public static Boolean isNumeric(String str) {
//?:0或1个, *:0或多个, +:1或多个 支持判断正负、整数小数
return str.matches("-?[0-9]+.?[0-9]*");
}