繁体   English   中英

如何使用Hibernate有效地从表中获取所有行?

[英]How to get all the rows from a table using Hibernate efficiently?

我希望使用休眠显示表中的所有行。 我使用了Hibernate 5。

我尝试了类似的方法,但是方法createCriteria显示为已贬值的方法。 请建议我一种有效的方法来从表中获取所有数据

session.createCriteria(Student.class).list();

我有一个像这样的Student Bean课程:

package com.Hibernate;

import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="student")
public class Student {

    @Id
    private int id;
    private String name;

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


}

并有一个Student.hbm.xml文件,如:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 4 Jun, 2019 3:36:17 PM by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
    <class name="com.Hibernate.Student" table="STUDENT">
        <id name="id" type="int">
            <column name="ID" />
            <generator class="assigned" />
        </id>
        <property name="name" type="java.lang.String">
            <column name="NAME" />
        </property>
    </class>
</hibernate-mapping>


在Hibernate 5+中使用CriteriaBuilderCriteriaQuery接口

// Create CriteriaBuilder
CriteriaBuilder builder = session.getCriteriaBuilder();

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

// Set root
Root<Student> root = criteria.from(Student.class);
criteria.select(root);

// Query execution
Query<Item> query = session.createQuery(criteria);
List<Item> results = query.getResultList();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM