①今天有个需求:api要求返回一个字符串,是一个集合所有元素以’,'隔开的形式
org.apache.commons.lang3.StringUtils.join(list, “,”)
②JPA一对多的关系中,当多方数据量庞大时使用子查询,比如订单和订单详情,商品和具体的SKU
private Specification<Item> createSpecification(ItemCriteria criteria) {
return (root, query, builder) -> {
//多方是子,所以query.subquery(这里就是多方)
var subQuery = query.subquery(Variation.class);
//通过subQuery获取子方的Root对象(用于获取下方的num字段去动态查询)
var subQRoot = subQuery.from(Variation.class);
subQuery.select(subQRoot);
//构建查询条件
List<Predicate> predicates = new ArrayList<>();
//一方和多方的关系要确定,不管有没有传参数num
predicates.add(builder.equal(root, subQRoot.get("item")));
if (criteria.getNum() != null) {
//传了就构建num的查询条件
predicates.add(builder.like(subQRoot.get(Variation_.NUM), "%" + criteria.getNum().getContains() + "%"));
}
subQuery.where(builder.and(predicates.toArray(new Predicate[predicates.size()])));
return builder.exists(subQuery);
};
}
3、平常我们在处理异常的时候要么是try、catch,要么就是往上抛(我通常是try一下,因为总得处理),然而这种方法可能会帮我们解决异常处理:
@SneakyThrows
写在方法上,他是lombok包下的,就是@setter,@getter注解一样的包,写上这个就不用往上抛,或者try了,最后他在编译时会自动生成try的
4、有时候我们会遇到求两个时间中隔了多少时间(这里拿秒来说),java。time包下有这么个类Duration,它有个between方法
Duration.between(time1, time2).get(SECONDS) > 15
这个表示time1和time2间隔时间大于15秒
5、我们通常会使用Object.equals(obj)这种方法去判断两个对象是否是一样的,然而这样写:
Objects.equals(obj1, obj2)
它的实现方法是这样的,方便多了(Objects 是java.util包下的):
public static boolean equals(Object a, Object b) {
return (a == b) || (a != null && a.equals(b));
}
6、在使用到字符串的去空格时,使用stringutils.trim(字符串),就不使用字符串.trim()这种方式了
7、我通常会在一些需要事务的方法上加上Transactional注解,然而如果只加上这个注解它只会遇到RuntimeException才会回滚,如果遇到除其之外的异常就不会了,比如IOException、SQLException等以及用户自定义的Exception异常,这时需要加上:
@Transactional(rollbackFor=Exception.class)
在@Transactional注解中如果不配置rollbackFor属性,那么事物只会在遇到RuntimeException的时候才会回滚,加上rollbackFor=Exception.class,可以让事物在遇到非运行时异常时也回滚
8、我们在处理一个问题时,可能会在项目启动时去执行一次,这时使用注解:
@PostConstruct
还有一些注解:
每隔120min执行一次:@Scheduled(fixedRate = 120 * 60 * 1000, initialDelay = 3 * 60 * 1000)
每天凌晨3点执行一次:@Scheduled(cron = “0 0 3 * * ?”)