假设,我的数据库中有两个表,我必须使用两个表编写一个连接查询。我在我的 MVC 项目中将其中一个表映射为实体类,但没有将另一个表映射为实体。所以当我运行 hql 时,加入会起作用吗?
如果没有,并且如果需要映射,我应该指定这些实体之间的约束(主/外键)吗?
我的应用程序只是从表中读取数据,因此我不想浪费太多时间来编写实体类。有没有使用休眠的简单方法?
假设,我的数据库中有两个表,我必须使用两个表编写一个连接查询。我在我的 MVC 项目中将其中一个表映射为实体类,但没有将另一个表映射为实体。所以当我运行 hql 时,加入会起作用吗?
如果没有,并且如果需要映射,我应该指定这些实体之间的约束(主/外键)吗?
我的应用程序只是从表中读取数据,因此我不想浪费太多时间来编写实体类。有没有使用休眠的简单方法?
Hibernate 只知道会话工厂中有什么。如果您还没有定义某个实体 Hibernate 永远不会知道 is,那么编写涉及该实体的 hql 是毫无疑问的。
或者,您可以从会话中获取连接,然后执行自定义 sql 而不是 hql。
要使用普通 sql,您可以使用以下内容:
getSession().doWork(新工作() {
@Override
public void execute(Connection connection) throws SQLException {
// TODO Auto-generated method stub
}
})
关于您的问题:HQL 仅适用于映射实体,但可以使用 ResultTranformer 返回未映射的对象,但不是您的情况。您可以仅使用 hql 所需的关系和属性创建不需要的实体的最小定义。
另一种解决方法是创建纯 SQL 查询并仅返回映射实体session.createSQLQuery(yourQuerySQL).addEntity(YourMappedEntity.class).