I\'m trying to use stream in java, i had a student class:
@Entity
@Data @AllArgsConstructor @NoArgsConstructor
public class Student {
@Id @GeneratedValue(str
The First problem is Stream.of will create an stream of int arrays instead of stream of Integer
For Example
Stream.of(empIds).forEach(System.out::println); //[I@7c3e4b1a
IntStream.of(empIds).forEach(System.out::println); //1 2 3
So use IntStream.of or Arrays.stream()
If findById() is returning Optional<Student> then use isPresent to process only the Optional objects that contain Student
Arrays.stream
List<Student> students= Arrays.stream(empIds)
.mapToObj(studentRepository::findById)
.filter(Optional::isPresent)
.map(Optional::get)
.collect(Collectors.toList());
IntStream.of
List<Student> students= IntStream.of(empIds)
.mapToObj(studentRepository::findById)
.filter(Optional::isPresent)
.map(Optional::get)
.collect(Collectors.toList());
In current approach your are returning List<Optional<Student>>
List<Optional<Student>> students= IntStream.of(empIds)
.map(studentRepository::findById).collect(Collectors.toList());
Thank you all, your answers helped me to derive a solution:
List<Student> students= Arrays.stream(empIds)
.mapToObj(id->
studentRepository.findById(id).get())
.collect(Collectors.toList());
And the response of deadpool is great also, we have to add .map(Optional::get) to get the stream of student because studentRepository::findById return stream of optioanl that's why the error.
List<Student> students= Arrays.stream(empIds)
.mapToObj(studentRepository::findById)
// .filter(Optional::isPresent)
.map(Optional::get)
.collect(Collectors.toList());
To be able to use it in map() function, StudentRepository.findById() needs to return Optional<Student> instead of just Student.