gpt4 book ai didi

java - hibernate 检索查询不起作用

转载 作者:行者123 更新时间:2023-11-30 22:20:28 26 4
gpt4 key购买 nike

我的 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com