开发工具分享
  • 首页
  • 计算科学
  • 文化旅游
  • 项目和网站
    • OSSEZ 计算技术
    • USRealEstate 社区
    • 地区文化
    • CWIKI.US
    • BUG.OSSEZ.COM
    • RSS.OSSEZ.COM
Computer Science
Computer Science

Java 如何将 List 转换为 MAP

有时候我们需要将给定的 List 转换为 Map。 如果你使用的是 Java 8 以后版本的话,Stream 是你的好朋友。 Java 8 public Map<Integer, Animal> convertListAfterJava8(List<Animal> list) { Map<Integer, Animal> map = list.stream() .collect(Collectors.toMap(Animal::getId, Function.identity())); return map; } 上面的代码可以非常容易的完成转换,我们有一个 Animal 对象的 List。 上面的代码将会把 Id 作为 Key,然后生成的 Map 是以 id 为 Key,Animal 为Value 的 Map。 Guava 如果使用 Guava 就更加简单了。 public Map<Integer, Animal> convertListWithGuava(List<Animal> list) { Map<Integer, Animal> map = Maps .uniqueIndex(list, Animal::getId); return map; } 使用 Maps 的工具类就可以了,这个工具类可以直接用。 更进一步 如果对需要生成的 Map 进行处理。 Key 是对象中的一个值,Value 是 List 对象中的另外一个值。 例如可以使用下面的代码: listingStatusList.stream().collect(Collectors.toMap(CListingStatus::getListingStatusKey, CListingStatus::getListingStatus)); 其中 CListingStatus 对象是这样定义的。 @Entity @Getter @Setter public class CListingStatus extends AbstractPersistable<Long> { @ManyToOne @JoinColumn(name = "rets_id", nullable = false) private ConfRets confRets; private String listingStatusKey; private ListingStatus listingStatus ; } 对 Map 中的对象设值 针对 Stream 中的对象,我们可能还需要重新设置为其他的对象。 这个时候我们就可以使用 lambda 函数了。 同样的代码: HashMap<String, Agent> agentHashMap = (HashMap) mlsAgentList.stream().collect(Collectors.toMap(MlsAgent::getMlsAgentId, mlsAgent -> { Agent agent = new Agent(); agent.setAgentId(mlsAgent.getMlsAgentId()); agent.setAgentNameFirst(mlsAgent.getNameFirst()); agent.setAgentNameLast(mlsAgent.getNameLast()); agent.setAgentEmail(mlsAgent.getEmail()); return agent; })); 我们返回的 Map 使用了一个新的对象为 Value。 上面针对 Stream 转换为 Map 的方法进行了一些小总结,这些方法可能实际编程的时候使用的频率比较高。 同时能够避免大量使用 For 循环的情况。 Stream 还是需要好好了解下的。   https://www.ossez.com/t/java-list-map/14144

2022年10月12日 0Comments 628Browse 0Like Read more
Computer Science

Spring Batch BATCH_JOB_INSTANCE 表不存在错误

在运行 Spring Batch 项目的时候,提示上面的错误信息: java.sql.SQLSyntaxErrorException: (conn=12433) Table 'usrealestate.BATCH_JOB_INSTANCE' doesn't exist     问题和解决 这个问题如果是使用 Hibernate 的会话,没有使用 Spring JPA 的话,通常是不会提示的。 如果你在 application.properties 文件中配置了数据库连接的话,通常会提示上面的错误。 这是因为,如果你没有使用 Spring JPA 的话,Spring Batch 会启用一个 H2 数据库,在这个数据库中,Sping 会对 Batch 需要的配置进行配置。 如果你使用 Spring JPA 的话,你需要 Spring Batch 帮你初始化表。 解决办法就是在项目配置文件中,设置: spring.batch.initialize-schema=ALWAYS 但是上面的内容会显示为被丢弃了。 在 2.7 的 Spring Boot 版本中,应该使用的配置为: spring.batch.jdbc.initialize-schema=ALWAYS 如果使用的是 IDEA 的话,上面的内容会自动提示。 当你第一运行你的项目的时候,数据库会创建下面一堆表。 18:46:43.516 [main] DEBUG o.m.jdbc.client.impl.StandardClient - execute query: CREATE TABLE BATCH_JOB_EXECUTION ( JOB_EXECUTION_ID BIGINT NOT NULL PRIMARY KEY , VERSION BIGINT , JOB_INSTANCE_ID BIGINT NOT NULL, CREATE_TIME DATETIME(6) NOT NULL, START_TIME DATETIME(6) DEFAULT NULL , END_TIME DATETIME(6) DEFAULT NULL , STATUS VARCHAR(10) , EXIT_CODE VARCHAR(2500) , EXIT_MESSAGE VARCHAR(2500) , LAST_UPDATED DATETIME(6), JOB_CONFIGURATION_LOCATION VARCHAR(2500) NULL, constraint JOB_INST_EXEC_FK foreign key (JOB_INSTANCE_ID) references BATCH_JOB_INSTANCE(JOB_INSTANCE_ID) ) ENGINE=InnoDB 18:46:45.087 [main] DEBUG o.m.jdbc.client.impl.StandardClient - execute query: CREATE TABLE BATCH_JOB_EXECUTION_PARAMS ( JOB_EXECUTION_ID BIGINT NOT NULL , TYPE_CD VARCHAR(6) NOT NULL , KEY_NAME VARCHAR(100) NOT NULL , STRING_VAL VARCHAR(250) , DATE_VAL DATETIME(6) DEFAULT NULL , LONG_VAL BIGINT , DOUBLE_VAL DOUBLE PRECISION , IDENTIFYING CHAR(1) NOT NULL , constraint JOB_EXEC_PARAMS_FK foreign key (JOB_EXECUTION_ID) references BATCH_JOB_EXECUTION(JOB_EXECUTION_ID) ) ENGINE=InnoDB 18:46:46.209 [main] DEBUG o.m.jdbc.client.impl.StandardClient - execute query: CREATE TABLE BATCH_STEP_EXECUTION ( STEP_EXECUTION_ID BIGINT NOT NULL PRIMARY KEY , VERSION BIGINT NOT NULL, STEP_NAME VARCHAR(100) NOT NULL, JOB_EXECUTION_ID BIGINT NOT NULL, START_TIME DATETIME(6) NOT NULL , END_TIME DATETIME(6) DEFAULT NULL , STATUS VARCHAR(10) , COMMIT_COUNT BIGINT , READ_COUNT BIGINT , FILTER_COUNT BIGINT , WRITE_COUNT BIGINT , READ_SKIP_COUNT BIGINT , WRITE_SKIP_COUNT BIGINT , PROCESS_SKIP_COUNT BIGINT , ROLLBACK_COUNT BIGINT , EXIT_CODE VARCHAR(2500) , EXIT_MESSAGE VARCHAR(2500) , LAST_UPDATED DATETIME(6), constraint JOB_EXEC_STEP_FK foreign key (JOB_EXECUTION_ID) references BATCH_JOB_EXECUTION(JOB_EXECUTION_ID) ) ENGINE=InnoDB 18:46:47.172 [main] DEBUG o.m.jdbc.client.impl.StandardClient -…

2022年10月11日 0Comments 643Browse 0Like Read more
Computer Science

Spring boot 启动错误:Could not resolve placeholder

在启动整个spring boot项目时,出现错误: Could not resolve placeholder 原因:没有指定好配置文件,因为src/main/resources下有多个配置文件,例如application-dev.properties, boss.properties等。     解决办法: 在application.properties中加入 spring.profiles.active=@env@ 很多时候,我们项目在开发环境和生成环境的环境配置是不一样的,例如,数据库配置,在开发的时候,我们一般用测试数据库,而在生产环境的时候,我们是用正式的数据,这时候,我们可以利用profile在不同的环境下配置用不同的配置文件或者不同的配置 spring boot允许你通过命名约定按照一定的格式(application-{profile}.properties来定义多个配置文件,然后通过在application.properyies通过spring.profiles.active来具体激活一个或者多个配置文件,如果没有没有指定任何profile的配置文件的话,spring boot默认会启动application-default.properties。   https://www.ossez.com/t/spring-boot-could-not-resolve-placeholder/14140

2022年10月11日 0Comments 728Browse 0Like Read more
Computer Science

Spring JPA 如何进行无参数查询布尔类型

根据官方的文档说明:Spring Data JPA - Reference Documentation     可以在查询的参数后面添加 True 或 False 来进行查询。 例如,如果需要对下面的参数进行查询: True findByActiveTrue() … where x.active = true False findByActiveFalse() … where x.active = false 那么我们在查询的接口上可以使用: @Query public Iterable<Entity> findByEnabledTrue(); 来完成查询。   https://www.ossez.com/t/spring-jpa/14137

2022年10月11日 0Comments 598Browse 0Like Read more
Computer Science

作为有强迫症的人怎么可能会让错误大大方方的存在

让编译能够通过是最基本的要求了。     是不会运行有错误存在的。   https://www.usreio.com/t/topic/302

2022年10月09日 0Comments 587Browse 0Like Read more
Computer Science

在国内小伙伴的帮助下已经出具雏形了

在国内小朋友的帮助下,已经初具雏形了。 为了帮助大家在签证时候的签证行政审查,我们做了一个小工具希望能够帮助到所有在路上的人。     要改的还在继续,我们还在持续推进喔。 https://www.usvisatrack.com/

2022年10月08日 0Comments 546Browse 0Like Read more
Computer Science

Spring 项目启动测试的时候错误:Unable to acquire JDBC Connection

我们在使用 Spring JPA 测试项目启动的时候,得到下面的错误: Unable to acquire JDBC Connection     问题和解决 出现这个问题的主要原因是我们在资源文件夹中还有一个 hibernate.properties 文件。 这个文件中配置了 Hibernate 的数据库参数。 因为这个文件的存在,对我们 Spring JPA 使用的数据源进行了干扰。 解决办法就是删除 Hibernate 的属性配置文件。     将上面的属性配置文件删除即可。   https://www.ossez.com/t/spring-unable-to-acquire-jdbc-connection/14133

2022年10月05日 0Comments 837Browse 0Like Read more
Computer Science

Spring 测试运行的时候提示 Unable to find a @SpringBootConfiguration 错误

Spring 进行测试的时候提示的错误信息如下: SEVERE: Caught exception while closing extension context: org.junit.jupiter.engine.descriptor.JupiterEngineExtensionContext@c63c11ed java.lang.IllegalStateException: Unable to find a @SpringBootConfiguration, you need to use @ContextConfiguration or @SpringBootTest(classes=...) with your test     问题和解决 这个问题的主要原因是测试的包和项目的包的路径可能不一致。 这将会导致测试没有办法找到有关 Spring 有关的配置。     对比上面的图,我们就可以看到这个问题。 解决方法就是确定包的路径是一致的,这样 Spring 的测试类可以找到 Spring 有关的配置。   https://www.ossez.com/t/spring-unable-to-find-a-springbootconfiguration/14132

2022年10月05日 0Comments 504Browse 0Like Read more
Computer Science

Java 属性文件乱码问题

属性文件乱码通常是中文乱码,在英文下通常没有这个问题。     如上图显示的,中文字符在属性文件中读取后会显示为乱码. 问题和解决 导致这个问题的主要原因是属性文件如果你不进行设置,那么将会默认使用 ISO-8859-1 字符集来存储的。 通常我们也不建议在属性文件中过多使用中文,一般来说属性文件都是一些配置,如果需要中文的配置可以存储在其他的文件中。 如果非要使用,也是可以的。 不修改字符集 在不修改字符集的情况,将中文字符使用 Unicode 来表示就可以了。 如上面的例子,使用下面的字符。 name = \u5C5E\u6027\u6587\u4EF6 Inject a value to a static field 在程序输出的时候就可以显示成中文了。 转换成 UTF-8 编码 可以把属性文件转换成 UTF-8 编码。 这个 IDEA 能够很好的帮我们进行转换。 选择文件编码,然后选择 UTF-8,然后选择后面的选项。     然后在更新过代码的属性文件中输中文。 再次运行后,我们就可以看到能够正常显示中文了。 如上图完成修改后,就可以显示中文了。   https://www.ossez.com/t/java/14131

2022年10月04日 0Comments 620Browse 0Like Read more
Computer Science

Spring Lombok 实体类死循环问题

在 Spring JPA 1 对多查询的时候出现死循环的问题。 如下图所示:     所有的配置都是正确的的,就是没有办法获得数据,并且出现死循环 问题和解决 因为使用lombak的 @Data ,在toString()方法中产生死循环。 因为我们使用了 @Data 注解。     所有让 lombok 定义的 @ToString 类将会实现一个 toString() 方法。 在默认的情况下,将会指向类的名称,同时和每一个字段。 例如在使用 lazy @OneToMany 方法调用 hashCode() 的时候,fetch 可能有所有的实体类,这个对应用程序的运行可能产生非常大的性能问题。 同时,如果你在事务以外使用的话,可能会得到 LazyInitializationException 异常。 如果查询一个User实体,并打印,打印调用的是toString() 方法,toString()方法里面又有关联Dept对象。 所以导致 User 和子对象之间的两个对象互相调用并打印,形成一个递归调用,最后堆栈溢出。 基于上面的考虑,我们认为 @EqualsAndHashCode 和@Data 不应该应用在 JPA 的实体类上使用。 @ToString 还是可以使用的,因为我们可以使用 @ToString.Exclude 来设置不需要的字段或者使用 @ToString(onlyExplicitlyIncluded = true ) 来移除类, 对于 non-lazy 字段,我们可以使用@ToString.Include 注解。 例如我们的解决方案就是在 JPA 实体类中只使用 @Getter @Setter 注解。   基于上面的原因,这也是很多人建议使用 Lombok 的原因。 我们的理解还是可以使用的,别滥用,别图省事一个 @Data 到头。   https://www.ossez.com/t/spring-lombok/14129

2022年10月03日 0Comments 644Browse 0Like Read more
1…6162636465…237
Archives
  • June 2026
  • May 2026
  • April 2026
  • March 2026
  • February 2026
  • January 2026
  • December 2025
  • November 2025
  • October 2025
  • September 2025
  • August 2025
  • July 2025
  • June 2025
  • May 2025
  • April 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • November 2024
  • October 2024
  • September 2024
  • August 2024
  • July 2024
  • June 2024
  • May 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • November 2023
  • October 2023
  • September 2023
  • August 2023
  • July 2023
  • June 2023
  • May 2023
  • April 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • May 2022
  • April 2022
  • March 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • June 2021
  • May 2021
  • April 2021
  • March 2021
  • February 2021
  • January 2021
  • December 2020
  • November 2020
  • October 2020
  • September 2020
  • August 2020
  • July 2020
  • June 2020
  • May 2020
  • April 2020
  • March 2020
  • February 2020
  • January 2020
  • December 2019
  • November 2019
  • October 2019
  • September 2019
  • August 2019
  • July 2019
  • June 2019
  • May 2019
  • April 2019
  • March 2019
  • February 2019
  • January 2019
  • December 2018
  • November 2018
  • October 2018
  • September 2018
  • August 2018
  • July 2018
  • June 2018
  • May 2018
  • April 2018
  • March 2018
Categories
  • Computer Science (2,367)
    • Confluence (663)
    • Gradle (12)
  • U.S. (513)
  • 文化旅游 (146)

COPYRIGHT © 2020 CWIKIUS. ALL RIGHTS RESERVED.

THEME KRATOS MADE BY VTROIS

湘ICP备2020018253号-1