2016-05-09 15 views
1

Ich habe versucht einfach JPA aplication mit MySQL und Hibernate zu schaffen, ich will Last 4 Sätze aus der Tabelle Student db tablejavax.ejb.EJBTransactionRolledbackException: Benannte Abfrage nicht gefunden: findAll

aber ich empfange diesen Fehler:

Exception in thread "main" javax.ejb.EJBTransactionRolledbackException: Named query not found: findAll 

Hier ist meine Entity Klasse

package entity; 

import javax.persistence.Column; 
import javax.persistence.Entity; 
import javax.persistence.GeneratedValue; 
import javax.persistence.GenerationType; 
import javax.persistence.Id; 
import javax.persistence.NamedQueries; 
import javax.persistence.NamedQuery; 
import javax.persistence.Table; 

@Entity 
@Table(name="student") 
@NamedQueries({ 
    @NamedQuery(name = "findAll", query = "select st from student st") 
    }) 
public class student{ 

    @Id 
    @GeneratedValue(strategy=GenerationType.AUTO) 
    private int id; 

    @Column(name="name") 
    private String name; 

    @Column(name="surname") 
    private String surname; 

    @Column(name="sex") 
    private String sex; 

    public student(String name, String surname, String sex) { 
     this.name = name; 
     this.surname = surname; 
     this.sex = sex; 
    } 

    public int getId() { 
     return id; 
    } 

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

    public String getName() { 
     return name; 
    } 

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

    public String getSurname() { 
     return surname; 
    } 

    public void setSurname(String surname) { 
     this.surname = surname; 
    } 

    public String getSex() { 
     return sex; 
    } 

    public void setSex(String sex) { 
     this.sex = sex; 
    } 

    @Override 
    public String toString() { 
     return "student [id=" + id + ", name=" + name + ", surname=" + surname + ", sex=" + sex + "]"; 

} 

DAO

package dao; 

import java.util.List; 

import javax.persistence.EntityManager; 
import javax.persistence.Query; 
import javax.persistence.TypedQuery; 

import entity.student; 

public class StudentDAO { 

    public List<student> getAllStd(EntityManager em){ 
     TypedQuery<student> q = em.createNamedQuery("findAll", student.class); 
     return q.getResultList();  
    }  
} 

und schließlich Bean, die die DAO-Methode aufruft

package test; 

import java.util.List; 

import javax.ejb.Stateless; 
import javax.persistence.EntityManager; 
import javax.persistence.PersistenceContext; 
import javax.persistence.TypedQuery; 

import dao.StudentDAO; 
import entity.student; 

@Stateless 
public class Test2Bean { 

    @PersistenceContext() 
    private EntityManager em;  

    public void getAllStudents(){ 
     StudentDAO stdDAO = new StudentDAO(); 
     List<student> students = stdDAO.getAllStd(em); 
     System.out.println(students.size()); 
    }  
} 

persistence.xml

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.0" 
xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation=" 
http://java.sun.com/xml/ns/persistence 
http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"> 
<persistence-unit name="mysql"> 
<provider>org.hibernate.ejb.HibernatePersistence</provider> 
<jta-data-source>java:jboss/mysqlds</jta-data-source> 
<exclude-unlisted-classes>false</exclude-unlisted-classes> 
<properties> 

<property name="hibernate.show_sql" value="true" /> 
<property name="hibernate.hbm2ddl.auto" value="update" /> 
<property name="hibernate.use_sql_comments" value="true" /> 
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" /> 
</properties> 

</persistence-unit> 

</persistence> 

Ich habe keine Ahnung, warum DAO-Methode kann nicht Zugang Abfrage, ich einige Testmethoden in Entitätsklasse gemacht und Die DAO-Methode hat Zugriff auf Entity Student.

Danke für alle Antworten

+0

haben Sie versucht, die Klasse in persistence.xml zu setzen? denn dann ist es bekannt und daher sollte NamedQuery geladen werden ... –

+0

Ich sehe keinen no-arg-Konstruktor auf Ihrer 'Studenten'-Einheit. Hast du einen da drin? –

Antwort

1

Versuchen ...

@Entity 
@Table(name="student") 
@NamedQueries({ 
@NamedQuery(name = "Student.findAll", query = "select st from student st") 
}) 
public class student{ 

Schüler hinzufügen. vor "findAll"

nicht sicher, ob das das ist, aber meine benannten Abfragen haben das normalerweise.

+0

Ja, ich kenne diesen Trick, alle Abfragen müssen einen eindeutigen Namen enthalten, ich möchte nur diesen Testcode einfach halten, aber ich bin mir dessen bewusst, danke –