java - hibernate 检索查询不起作用

标签 java mysql hibernate

我的 JSF2 代码中有一个 hibernate 实现,试图从 MySQL 数据库中列出一些记录。有以下代码片段: Search.java - 实现查询逻辑; Student.java - 实现记录保存逻辑。

我面临的问题是每当我运行 Search.java 时,返回的结果都是“null”。

请注意 - 我的数据库已经有很多条目,甚至当我尝试查询 Student myStudent = session.get(Student.class, 23); 时它也返回了“null”。
这里的 23 是 SQL 表中的 id 字段。此外,该表具有自动生成的 PK 作为 id。我还有另一个用于插入记录的类,效果非常好。

搜索.java:

public class Search {

    public static void main(String[] args) {

        // create session factory
        SessionFactory factory = new Configuration().configure("hibernate.cfg.xml")
            .addAnnotatedClass(Student.class).buildSessionFactory();

        // create session
        Session session = factory.getCurrentSession();

        try {

            // start a transaction
            Student tempStudent = new Student("bob", "thebuilder", "good", "blabla@bla.com", "(456)-456 5897");
            session.beginTransaction();

            session.save(tempStudent);

            // commit transaction
            session.getTransaction().commit();
            System.out.println("id of the student is " + tempStudent.getId());

            session = factory.getCurrentSession();
            session.beginTransaction();

            System.out.println("student with id " + tempStudent.getId());
            Student myStudent = session.get(Student.class, tempStudent.getId());

            session.getTransaction().commit();

            System.out.println("Done!");
        } finally {
            factory.close();
        }
    }
}

请指出我可能在这里犯了什么错误。我花了几个小时谷歌搜索。另外,请原谅我的(可能)菜鸟错误,我是 Hibernate 和这个网站的新手。

让我知道是否需要发布错误堆栈或我的 cfg.xml

最佳答案

正如我在您的案例中看到的,tempStudent 的 id 为 0。您需要通过已保存学生的 id 从 session 中获取。 试试这个:

Serializable id= session.save(tempStudent);
...
Student myStudent = session.get(Student.class, id);

您还可以在 hibernate.cfg 文件中启用 show_sql 属性。它将记录所有生成的 sql,因此您可以检查是否正常。

关于java - hibernate 检索查询不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36736053/

相关文章:

java - 带有适配器 ""的 ViewPager 需要 AsyncTask 中的 View id

mysql - 在 MYSQL Workbench 中逆向工程插入脚本

java - 尝试在不同的类中使用@transient变量

java - 文档.newPage();不在 iText 中的每个循环内部工作

java - 找不到合适的方法来解析(java.io.InputStream)

java - 在谷歌地图 json 数据中的地点类型中搜索特定项目

mysql - Django ORM Join 语句

php - 使用 Foreach 用数组更新 MySQL 表

java - 如何在spring上正确地从file.properties设置hibernate?

hibernate - "Transaction in view"与 Hibernate、Spring、Struts