вчера я наткнулся на странное поведение Java / Spring / IntelliJ, которое мне не удалось объяснить.
Это приложение Spring Boot, созданное с помощью jdk1.8.0_152.
Я запустилэтот простой 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');
Вот мой класс Entity:
@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 он показывает значения следующим образом:
Как это возможно?Почему я могу иметь длинные значения в списке строк?
Также:
values.add(1L) // fails to compile
values.get(0).getClass().name // returns java.lang.String
values.get(1).getClass().name // returns java.lang.Long