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
.