昨天我偶然发现了一些我无法解释的奇怪的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 {
@Query("SELECT new map(id as key, name as value) FROM TestOrganization")
List> findAllAndMapById();
}
这就是让事情变得混乱的地方.
我编写了一个简单的单元测试来检查值,但结果证明它在第二个断言时失败:
@Test
public void shouldGetDocumentByName() {
List values = testOrganizationRepository.findAllAndMapById()
.stream()
.flatMap( m -> m.values().stream() )
.collect( Collectors.toList() );
assertThat( values ).isNotEmpty();
assertThat( values ).allMatch( n -> n instanceof String );
}
使用IntelliJ进行调试时,它显示如下值:
这怎么可能?为什么我能在String的List中包含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