昨天我偶然发现了一些我无法解释的奇怪的 Java/Spring/IntelliJ 行为。
这是一个使用 jdk1.8.0_152 制作的 Spring Boot 应用程序。
我运行了这个简单的 SQL 来填充我的数据库:
CREATE TABLE TEST_ORGANIZATION
(
ID NUMBER(19) NOT NULL,
NAME VARCHAR(255) NOT NULL
);
INSERT INTO TEST_ORGANIZATION (ID, NAME) VALUES ('1', 'test1');
INSERT INTO TEST_ORGANIZATION (ID, NAME) VALUES ('2', 'test2');
这是我的实体类:
@Data
@NoArgsConstructor
@Entity
public class TestOrganization {
@Id
private Long id;
@NotNull
private String name;
}
还有我的 JPA 存储库:
public interface TestOrganizationRepository extends JpaRepository<TestOrganization, Long> {
@Query("SELECT new map(id as key, name as value) FROM TestOrganization")
List<Map<String, String>> findAllAndMapById();
}
这就是事情变得混乱的地方。我编写了一个简单的单元测试来检查值,但结果在第二次断言时失败:
@Test
public void shouldGetDocumentByName() {
List<String> values = testOrganizationRepository.findAllAndMapById()
.stream()
.flatMap( m -> m.values().stream() )
.collect( Collectors.toList() );
assertThat( values ).isNotEmpty();
assertThat( values ).allMatch( n -> n instanceof String );
}
使用 IntelliJ 进行调试时,它显示如下值:
这怎么可能?为什么我可以在字符串列表中拥有 Long 值?
还:
values.add(1L) // fails to compile
values.get(0).getClass().name // returns java.lang.String
values.get(1).getClass().name // returns java.lang.Long
繁星点点滴滴
幕布斯7119047
鸿蒙传说
相关分类