首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如果参与联接的表没有被映射为hibernate配置中的实体,那么联接是否可以在hibernate中工作?

如果参与联接的表没有被映射为hibernate配置中的实体,那么联接是否可以在hibernate中工作?
EN

Stack Overflow用户
提问于 2013-08-05 02:16:20
回答 2查看 108关注 0票数 0

让我们假设,我的数据库中有两个表,并且我必须使用这两个表编写一个连接查询。在我的MVC项目中,我将其中一个表映射为实体类,但没有将另一个表映射为实体。那么,当我运行hql时,这个连接会起作用吗?

如果没有,如果有必要有一个映射,我应该指定这些实体之间的约束(主键/外键)吗?

我的应用程序只是从表中读取数据,因此我不想浪费太多时间编写实体类。使用hibernate有什么简单的方法吗?

EN

回答 2

Stack Overflow用户

发布于 2013-08-05 02:50:29

Hibernate只知道会话工厂中有什么。如果您没有定义某个实体,那么Hibernate永远不会知道is,所以编写涉及该实体hql是不成问题的。

或者,您可以从会话中获取连接,然后执行自定义sql而不是hql。

要使用纯sql,您可以使用以下内容:

getSession().doWork(新作品(){

代码语言:javascript
运行
复制
        @Override
        public void execute(Connection connection) throws SQLException {
            // TODO Auto-generated method stub

        }
    })
票数 1
EN

Stack Overflow用户

发布于 2013-08-05 02:50:57

关于您的问题: HQL只适用于映射的实体,但可以使用ResultTranformer返回未映射的对象,但不是您的情况。您可以使用hql所需的关系和属性来创建不需要的实体的最小定义。

另一种解决方法是创建纯SQL查询,并只返回带有session.createSQLQuery(yourQuerySQL).addEntity(YourMappedEntity.class).的映射实体

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18046037

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档