java map 多种类型吗_是多种类型的Java列表是否可行

昨天我偶然发现了一些我无法解释的奇怪的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进行调试时,它显示如下值:

JaLoS.png

这怎么可能?为什么我能在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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值