I've set a NamedQuery like this:
@Entity
@Table(name = "channel")
@NamedQuery(name = "Channel.getPrivateChannel", query = "SELECT pvt from Channel pvt WHERE pvt.state = 3 AND pvt.channelOwnerWorkspace = :channelOwnerWorkspace AND pvt.channelSubscribers = :channelSubscribers")
public class Channel implements Serializable {
...
@Column(nullable = false)
private int type;
@ManyToOne
@JoinColumn(name = "workspaceId")
private Workspace channelOwnerWorkspace;
@ManyToMany(mappedBy = "subscribedChannels", fetch = FetchType.EAGER)
private Set<User> channelSubscribers;
All the variables are non null and exist; and, when calling said Query, I get an IllegalArgumentException like this:
Parameter value [pt.project.entity.User@4125ce40] did not match expected type [java.util.Set (n/a)]
The exception is thrown here:
public Channel findPrivateChannel1(String workspace, Set<User> channelSubscribers) {
///
Workspace selectedWorkspace = workspaceDAO.findByTitle(workspace);
try {
Channel pvtChannel = em.createNamedQuery("Channel.getPrivateChannel", Channel.class)
.setParameter("channelOwnerWorkspace", selectedWorkspace)
.setParameter("channelSubscribers", channelSubscribers).getSingleResult();
What am I doing wrong? Is it even possible to set an HashSet as parameter?
Thanks in advance.