20230901工作心得:IDEA列操作&lambda表达式加强版用法

今天是中小学开学时间,亦是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。

相关推荐
AI视觉网奇5 小时前
pycharm 左右箭头 最近编辑
ide·python·pycharm
思绪无限5 小时前
Pycharm的终端无法使用Anaconda命令行问题详细解决教程
ide·python·pycharm·终端·命令行·anaconda·问题教程
漫步云端-r5 小时前
Pycharm的使用技巧总结
ide·python·pycharm
朝新_6 小时前
【多线程初阶】阻塞队列 & 生产者消费者模型
java·开发语言·javaee
立莹Sir6 小时前
Calendar类日期设置进位问题
java·开发语言
季鸢7 小时前
Java设计模式之状态模式详解
java·设计模式·状态模式
@yanyu6668 小时前
springboot实现查询学生
java·spring boot·后端
ascarl20108 小时前
准确--k8s cgroup问题排查
java·开发语言
magic 2458 小时前
Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误
java