gpt4 book ai didi

mysql - 从表中的外键映射值

转载 作者:行者123 更新时间:2023-11-29 12:55:21 24 4
gpt4 key购买 nike

我在我的项目中使用 hibernate,我本质上想做的是弄清楚如何将带有外键的值从数据库中的表自动映射到数据对象。

例如,我有一个包含以下列的用户表

id - INT
username - VARCHAR
password - VARCHAR
email - VARCHAR
firstName - VARCHAR
lastName - VARCHAR

这很容易映射,因为不涉及外键。我的代码是:

SQLQuery q = session.createSQLQuery("SELECT * FROM users WHERE username=? AND password=?");
q.setString(0, username);
q.setString(1, password);
q.addEntity(User.class);

List<User> users = q.list()

现在假设我向用户表添加一些外键,例如

userlevel_id - INT
department_id - INT

引用用户所属的用户级别和部门。如何让 hibernate 映射用户级别表中的用户级别名称和部门表中的部门名称?如果我只是将 id 存储在用户数据对象中,那么它不会有多大用处,因为稍后我需要将这些值显示到我的 View 中。任何帮助将不胜感激,谢谢!

最佳答案

在您的 User 对象上使用预先加载的 @ManyToOne 映射。创建一个对象来代表您的 DepartmentUserLevel 并将它们作为字段添加到您的 User 对象中。您应该急切加载此映射的原因是,在任何情况下您都不想加载没有 DepartmentUserLevel 的 User 。 Hibernate 会自动将您的 User 对象映射到适当的 DepartmentUserLevel

如果你也想要的话,可以建立关系bi-directional这样就可以通过选择一个部门来获取该部门的所有用户。您可以在 SQL 中执行的任何操作都可以使用 Hibernate 进行映射。

阅读文档并看看是否有帮助。

关于mysql - 从表中的外键映射值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24148002/

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