今天是中小学开学时间,亦是9月的开始,继续努力。
今日收获较大的有四个地方,先说这四点。
1、IDEA列操作
使用场景:需要批量将Excel表格里的数据插入到数据库中,此时需要写大量的insert SQL语句。
比如像这样的,密码麻麻的,可能要插入几百条数据。
一条一条写,要写到天荒地老。所以就需要IDEA里的列操作。
具体操作是:
按住Alt,找到要批量操作的位置,然后鼠标向下拖动。
但是有特殊情况,当上下不一齐的时候,这个方法就会失效。比如,这里,我要修改他们的年龄,但是按Alt然后往下拖动的时候,光标总是错位。
即使你按方向键,->,也会错位。
你可以这样操作:
如果每列开始位置不一样,先从整齐的那一列开始,按alt往下拖,然后ctrl + shift +左/右箭头或ctrl + w。跳到目标位置,然后按右键盘,停在那里,然后再ctrl + shift +左/右箭头,选择某个模块的信息,修改。
然后ctrl + shift +左/右箭头或ctrl + w,跳到目标位置
然后再ctrl + shift +左/右箭头,选择某个模块的信息,修改。
2、Lambda表达式加强版用法
以xx为分组,对象作为list。
Map<String, List<User>> something = list.stream().collect(Collectors.groupingBy(User::getName));
还可以xx为分组,然后进一步抽取具体的某个属性为list。
//这里是假代码,仅作示意
Map<String, List<name>> groupingByNameAge= list.stream().collect(Collectors.groupingBy(People::getName,Collectors.mapping(People::getFriends,Collectors.toList())));
3、标志位 没有返回
某天我写过巧用标志位,做标记,20230830工作心得:巧用标记位和For循环遍历但是在那里,我没有返回标志位,导致这个标志位没有更新,没有传递,相当于白写。
for (String phone : xxxGroupByPhone.keySet()) { Boolean isTransmitted = false; List<UserClue> phoneClue = xxxGroupByPhone.get(phone); for (UserClue userClue : phoneClue) { isTransmitted = pushClueItem(userClue,isTransmitted); } }
private Boolean pushClue(UserClue userClue,Boolean isTransmitted ) { if(xx){ return true; }; if(xx){ return false; } }
执行顺序:
4、善用Optional避免空指针
Optional<Order> optional = OrderRepository.findFirstByOrderNo(orderNo);
return optional.map(this::decryOrder).orElse(null);
查询订单号为 orderNo 的第一个订单,并掉用this::decryOrder方法,将其加密后返回。如果没有找到匹配的订单,则返回 null。