Hibernate Query NullPointerException(@ManyToMany)

时间:2013-10-18 15:52:56

标签: java hibernate ejb many-to-many hql

我还在接受教育,请耐心等待。 :-) 我有Class Teilnehmer.Java

@Entity
@Table(name = "Teilnehmer")
public class Teilnehmer implements java.io.Serializable {
private Integer id;
private String nachname;
private String vorname;
private String email;
@Type(type="org.domain.tkt.entity.EnumUserType",parameters={@org.hibernate.annotations.Parameter(name="type",value="org.domain.tkt.entity.Gender")})
private Gender gender;
private List<Team> teams = new ArrayList<Team>();;
private String userName;
private Rolle rolle;


public Teilnehmer() {
}

@Column(name = "user_name",unique = true,length = 16)
@Length(min = 4,max = 16)
@Pattern(regex = "^[a-zA-Z\\d_]{4,12}$",message = "{invalid_screen_name}")
@UserPrincipal
public String getUserName() {
    return this.userName;
}

public void setUserName(String userName) {
    this.userName = userName;
}

我有Class Team.Java

@Entity
@Table(name = "Team")
public class Team implements java.io.Serializable, Comparable<Team>  {

private Integer id;
private String name;
private List<Teilnehmer> teilnehmer = new ArrayList<Teilnehmer>();;
private List<Spielelement> spielelements = new ArrayList<Spielelement>();;
private List<Turnier> turniere = new ArrayList<Turnier>();;

public Team() { }

@ManyToMany
public List<Teilnehmer> getTeilnehmer() {
    teilnehmer.size();
    return teilnehmer;
}

public void setTeilnehmer(List<Teilnehmer> teilnehmer) {
    this.teilnehmer = teilnehmer;
}

首先:我打赌@ManyToMany注释存在问题,因为StackOverflow中没有像JoinColumn那样的问题,但我的主要问题是。我有一个第三课,我尝试用他的用户名获得实际的Teilnehmer(这是一个用户),但我会得到一个NullPointer ..

protected Teilnehmer byUserName(String userName) {
    try {
        Query q = entityManager.createQuery("select Teilnehmer from Teilnehmer as teilnehmer inner join teilnehmer.userName as name where name like :userName");
        q.setParameter("userName", userName);
        return (Teilnehmer)q.getSingleResult();
    } catch (javax.persistence.NoResultException nre) {
        return null;
    }
}

这是在控制台中创建的QRY Hibernate ..第一部分看起来很棒..但我不知道为什么它会在角色的一部分崩溃。在数据库中,roleId的值为'9047',那是正确的..

17:33:42,562 INFO  [STDOUT] Hibernate: 
select
    teilnehmer0_.id as id7_,
    teilnehmer0_.user_name as user2_7_,
    teilnehmer0_.email as email7_,
    teilnehmer0_.nachname as nachname7_,
    teilnehmer0_.vorname as vorname7_,
    teilnehmer0_.rolle_rolle_id as rolle14_7_,
    teilnehmer0_.gender as gender7_,
    teilnehmer0_.photo as photo7_,
    teilnehmer0_.created_on as created8_7_,
    teilnehmer0_.abteilung_id as abteilung15_7_,
    teilnehmer0_.password as password7_,
    teilnehmer0_.activation_key as activation10_7_,
    teilnehmer0_.photo_image_type as photo11_7_,
    teilnehmer0_.temporary_password as temporary12_7_,
    teilnehmer0_.active as active7_ 
from
    Teilnehmer teilnehmer0_ 
where
    teilnehmer0_.user_name=?
17:33:42,595 INFO  [STDOUT] Hibernate: 
select
    rolle0_.rolle_id as rolle1_11_0_,
    rolle0_.name as name11_0_,
    rolle0_.beschreibung as beschrei3_11_0_ 
from
    rolle rolle0_ 
where
    rolle0_.rolle_id=?
17:33:42,624 FATAL [application] java.lang.NullPointerException
javax.faces.el.EvaluationException: java.lang.NullPointerException
at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:91)
at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:91)
at javax.faces.component.UICommand.broadcast(UICommand.java:383)
at org.ajax4jsf.component.AjaxViewRoot.processEvents(AjaxViewRoot.java:329)
at org.ajax4jsf.component.AjaxViewRoot.broadcastEventsForPhase(AjaxViewRoot.java:304)
at org.ajax4jsf.component.AjaxViewRoot.processPhase(AjaxViewRoot.java:261)
at org.ajax4jsf.component.AjaxViewRoot.processApplication(AjaxViewRoot.java:474)
at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:97)
at com.sun.faces.lifecycle.LifecycleImpl.phase(LifecycleImpl.java:251)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:117)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:244)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.domain.tkt.entity.IE9CompatablityFilter.doFilter(IE9CompatablityFilter.java:23)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:83)
at org.jboss.seam.web.IdentityFilter.doFilter(IdentityFilter.java:40)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.web.MultipartFilter.doFilter(MultipartFilter.java:90)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.web.ExceptionFilter.doFilter(ExceptionFilter.java:64)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.web.RedirectFilter.doFilter(RedirectFilter.java:45)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.ajax4jsf.webapp.BaseXMLFilter.doXmlFilter(BaseXMLFilter.java:206)
at org.ajax4jsf.webapp.BaseFilter.handleRequest(BaseFilter.java:290)
at org.ajax4jsf.webapp.BaseFilter.processUploadsAndHandleRequest(BaseFilter.java:388)
at org.ajax4jsf.webapp.BaseFilter.doFilter(BaseFilter.java:515)
at org.jboss.seam.web.Ajax4jsfFilter.doFilter(Ajax4jsfFilter.java:56)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.web.LoggingFilter.doFilter(LoggingFilter.java:60)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.web.HotDeployFilter.doFilter(HotDeployFilter.java:53)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.servlet.SeamFilter.doFilter(SeamFilter.java:158)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:179)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:433)
at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:84)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
at org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:156)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:241)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:580)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Unknown Source)

我无法弄清楚什么是错的。顺便说一下:byName(String userName)中userName字符串中的值是正确的,它不是null。 MHMM ....

至少是角色的类(Rolle.Java)

@Entity
@Table(name="rolle")
public class Rolle implements java.io.Serializable {

static final long serialVersionUID=-2631452282682699312L;

private Long roleId;
private String beschreibung;
private String name;
private Set<Teilnehmer> teilnehmer;

public void setTeilnehmer(Set<Teilnehmer> teilnehmer) {
    this.teilnehmer = teilnehmer;
}

@OneToMany(mappedBy="rolle")
public Set<Teilnehmer> getTeilnehmer()
{
    return this.teilnehmer;
}

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name="rolle_id")
public Long getRoleId() {
    return this.roleId;
}

public void setRoleId(Long roleId) {
    this.roleId=roleId;
}

@Column(name="beschreibung",nullable=false,length=90)
@NotNull
@Length(max=90)
public String getBeschreibung() {
    return this.beschreibung;
}

public void setBeschreibung(String description) {
    this.beschreibung=description;
}

@Column(name="name",unique=true,nullable=false,length=30)
@NotNull
@Length(min=4,max=30)
@RoleName
@Pattern(regex="^[a-zA-Z\\d_]{4,12}$",message="{invalid_role_name}")
public String getName() {
    return this.name;
}

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

}

1 个答案:

答案 0 :(得分:0)

您可以使用getResultList().get(0)代替getSingleResult()。 如下设置byUserName()方法可以解决您的问题

 protected Teilnehmer byUserName(String userName) {
   Teilnehmer t=null;
   try {
        Query q = entityManager.createQuery("select teilnehmer  from  "+Teilnehmer.class.getName() +" as teilnehmer inner join teilnehmer.userName as name where name like :userName");
        q.setParameter("userName", userName);
        t=(Teilnehmer)q.getResultList().get(0);
    } catch (javax.persistence.NoResultException nre) {

    }
   return t;
}