Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/369.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 使用userId创建对象列表_Java_Spring - Fatal编程技术网

Java 使用userId创建对象列表

Java 使用userId创建对象列表,java,spring,Java,Spring,我有一个应用程序,用户可以将电影标题添加到列表中。目前我使用此代码返回列表: @Override public List<Movie> getAllmovies() { List<Movie> movies = new ArrayList<Movie>(); Iterator<Movie> iterator = movieRepository.findAll().iterator(); while (iterator.h

我有一个应用程序,用户可以将电影标题添加到列表中。目前我使用此代码返回列表:

@Override 
public List<Movie> getAllmovies() {

    List<Movie> movies = new ArrayList<Movie>();
    Iterator<Movie> iterator = movieRepository.findAll().iterator();
    while (iterator.hasNext()) {
        movies.add(iterator.next());
    }

    return movies;
}
我在我的电影记录片中添加了这个方法:

@Repository
public interface MovieRepository extends JpaRepository<Movie, Serializable> {
    List<Movie> findAllByUserId(Long userId);
}

以下方法签名将获得您想要的:

List<Movie> findByUsers_Id(Long id)
List findByUsers\u Id(长Id)
这是使用SpringDataJPA的属性表达式特性。签名用户Id将被转换为JPQL
x.Users.Id


请把您的
电影
型号包括在内好吗?您是否也尝试过打开SQL日志以查看正在执行的SQL-
logging.level.org.hibernate.SQL=debug
我添加了电影模型。我来看看执行了什么SQL。电影没有userId属性,因为这与电影无关。非常接近,但目前为止。欢呼声起了作用。正在阅读信息!很高兴听到,如果答案有效,请随意接受;)哈哈
package com.movieseat.models;

import com.movieseat.model.security.User;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.ManyToMany;
import javax.persistence.Table;

@Entity(name = "Movie")
@Table(name = "movie")
public class Movie {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "id")
    private Integer id;

    private String name;

    public Movie(){}

    public Movie(String name) {
        this.name = name;
    }

    public Movie(Integer id, String name ) {
        this.id = id;
        this.name = name;
    }

    public Movie(String name, Set<User> users){
        this.name = name;
        this.users = users;
    }    

    @ManyToMany(mappedBy = "movies")
    private Set<User> users = new HashSet<>(); 

    public Set<User> getUsers() {
        return users;
    }

    public void setUsers(Set<User> users) {
        this.users = users;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString(){
        return "id: " + id + "name: " + name;
    }

}
List<Movie> findByUsers_Id(Long id)