Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/352.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如果参与联接的表在hibernate配置中未映射为实体,则联接是否在hibernate中工作?_Java_Spring_Hibernate_Model View Controller_Entity - Fatal编程技术网

Java 如果参与联接的表在hibernate配置中未映射为实体,则联接是否在hibernate中工作?

Java 如果参与联接的表在hibernate配置中未映射为实体,则联接是否在hibernate中工作?,java,spring,hibernate,model-view-controller,entity,Java,Spring,Hibernate,Model View Controller,Entity,假设我的数据库中有两个表,我必须使用两个表编写连接查询。在MVC项目中,我将其中一个表映射为实体类,但另一个表没有映射为实体。 所以,当我运行hql时,这会起作用吗 如果没有,并且如果有必要进行映射,我是否应该指定这些实体之间的约束(主键/外键) 我的应用程序只是从表中读取数据,因此我不想浪费太多时间编写实体类。使用hibernate有什么简单的方法吗?hibernate只知道会话工厂中有什么。如果您还没有定义Hibernate永远不会知道的某个实体,那么编写涉及该实体的hql是毫无疑问的 或者

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

如果没有,并且如果有必要进行映射,我是否应该指定这些实体之间的约束(主键/外键)


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

hibernate只知道会话工厂中有什么。如果您还没有定义Hibernate永远不会知道的某个实体,那么编写涉及该实体的hql是毫无疑问的

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

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

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


关于您的问题:HQL仅适用于映射实体,但可以使用ResultTranformer返回not mapped object,但这不是您的情况。您可以使用HQL所需的关系和属性创建不需要的实体的最小定义。

另一种解决方法是创建普通SQL查询,并使用
session.createSQLQuery(yourQuerySQL).addEntity(yourMappedenty.class)仅返回映射实体。

“欢迎使用SO。如果以下答案之一解决了您的问题,您应该接受它(单击相应答案旁边的复选标记)。这有两个作用。它让每个人都知道您的问题已经解决,并让帮助您的人相信您的帮助。请参阅此处以获取完整的解释。”
        @Override
        public void execute(Connection connection) throws SQLException {
            // TODO Auto-generated method stub

        }
    })