Как получить все данные в таблице с Hibernate?

public Service getServiceData(){
    return (Service)ServiceDaoImpl.getSession().get(Service.class, new Integer(1));
}

Метод get получает один. Я хочу получить все данные для страницы JSP.

7 ответов

С Hibernate 5 createCriteria не рекомендуется использовать что-то вроде этого

private static <T> List<T> loadAllData(Class<T> type, Session session) {
    CriteriaBuilder builder = session.getCriteriaBuilder();
    CriteriaQuery<T> criteria = builder.createQuery(type);
    criteria.from(type);
    List<T> data = session.createQuery(criteria).getResultList();
    return data;
  }

использование

Session session = HibernateUtils.getSession();
List<User> users = loadAllData(User.class, session);

Попробуйте приведенный ниже фрагмент кода и замените Entity вашим классом Entity

@SuppressWarnings("unchecked")      
public List<Entity> getAlldata(){       
    try
    {
        return sessionFactory.getCurrentSession().createCriteria(Entity.class).list();
    } catch (Exception e) {
        return new ArrayList<>();
    }
}

Попробуйте следующим образом получить все строки из таблицы

@SuppressWarnings("unchecked")
    public List<Service> Service getServiceData() {

         return ServiceDaoImpl.getSession().createQuery("from Service").list(); 
    }

Поскольку List<Entity> list = session.createCriteria(Entity.class).list();деприминирован,

Вы можете использовать CriteriaBuilder().

        try ( Session session = sessionFactory.openSession()) {
            // Create CriteriaBuilder
            CriteriaBuilder builder = session.getCriteriaBuilder();

            // Create CriteriaQuery
            CriteriaQuery<Entity> criteria = builder.createQuery(Entity.class);

            // Specify criteria root
            criteria.from(Entity.class);

            // Execute query
            List<Entity> entityList = session.createQuery(criteria).getResultList();

            for (Entity e : entityList) {
             // load the data
            }
        }

Щелкните здесь, чтобы увидеть пример на github.

public List<Service> getServiceAll(){
     return ServiceDaoImpl.getSession().createCriteria(Service.class).list();
}

Конфигурация cfg = новая конфигурация (); cfg.configure("hibernate.cfg.xml");

    SessionFactory factory = cfg.buildSessionFactory();
    Session session = factory.openSession();

    /* Selecting all objects(records) start_______________________ */



    Query qry = session.createQuery("from Product p");

    List l =qry.list();
    System.out.println("Total Number Of Records : "+l.size());
    Iterator it = l.iterator();

    while(it.hasNext())
    {
        Object o = (Object)it.next();
        Product p = (Product)o;
        System.out.println("Product id : "+p.getProductId());
        System.out.println("Product Name : "+p.getProName());
        System.out.println("Product Price : "+p.getPrice());
        System.out.println("----------------------");
    }       

    session.close();
    factory.close();

Используя нативный запрос

        Session session = sessionFactory.openSession();
        try {
            List<Book> bookList = session.createNativeQuery("Select * from book", Book.class).getResultList();
            return bookList;
        }catch (Exception e){
            return null;
        }finally {
            session.close();
        }
Другие вопросы по тегам