2016-05-09 3 views
1

Я пытался создать простой JPA, используя MySql-анкету и спящий режим, я хочу загружать 4 записи из таблицы студента db tablejavax.ejb.EJBTransactionRolledbackException: Названный запрос не найден: FindAll

, но я получаю эту ошибку:

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

Вот мой Entity Класс

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();  
    }  
} 

и, наконец, боб, который вызывает метод DAO

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> 

я понятия не имею, почему запрос метод доступа DAO косяк, я сделал несколько методов тестирования в классе сущностей и Метод DAO имеет доступ к Entity Student.

Спасибо за все ответы

+0

Вы пробовали сдавать класс в persistence.xml? потому что тогда это известно о и, следовательно, любой NamedQuery должен быть загружен ... –

+0

Я не вижу конструктора no-arg в вашей сущности 'student'. У вас там есть? –

ответ

1

Try ...

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

Добавить Студента. перед «findAll»

не уверен, что это все, но мои именованные запросы обычно имеют это.

+0

Да, я знаю этот трюк, все запросы должны содержать уникальное имя, я просто хочу, чтобы этот тестовый код был прост, но я знаю об этом, спасибо –

Смежные вопросы