1

我们有一个新的 web 应用程序,正在准备部署。我们更改了包含 jar 的方式,从手动将它们转储到 web-inf/lib 中,改为使用 eclipse 的部署程序集将它们从公共位置动态移动到 web-inf/lib 中,为我们的库创建一个存储库。这种策略适用于除了一个罐子之外的所有东西……我们的休眠实体所在的罐子。

罐子在那里,我们可以看到它。它在类路径中,我们可以实例化它。但是当我们运行时,我们会得到一个未知实体的异常,就好像来自目标实体的注释从未运行过一样。当我们用“annotatedClasses”列表替换我们的“packagesToScan”声明时,它工作正常。然而我们的 packagesToScan 看起来是正确的。我宁愿使用灵活的 packagesToScan,也不愿让开发人员每次都做容易忘记的声明他们的类的步骤。

有人知道为什么会这样吗?

spring config(下面同时显示所有三个,实际上我们一次注释一个):

<bean id="rptappSessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
  <property name="dataSource" ref="rptappDataSource" />
  <!-- works -->
  <property name="annotatedClasses">
    <list><value>a.b.c.report.model.table.BOReportTask</value></list>
  </property>
  <!-- does not work -->
  <property name="packagesToScan">
    <list><value>a.b.c.report.model.table</value></list>
  </property>
  <!-- also does not work -->
  <property name="packagesToScan" value="a.b.*" />
  <property name="hibernateProperties">
    <props>
      <prop key="hibernate.dialect">org.hibernate.dialect.DB2Dialect</prop>
      <prop key="hibernate.connection.driver_class">com.ibm.db2.jcc.DB2Driver</prop>
      <prop key="hibernate.bytecode.provider">javassist</prop>
      <prop key="hibernate.show_sql">${hibernate.show.sql}</prop>
      <prop key="format_sql">false</prop>
      <prop key="use_sql_comments">false</prop>
      <prop key="hibernate.cache.use_second_level_cache">false</prop>
      <prop key="hibernate.default_schema">K702PRDR</prop>
    </props>
  </property>
</bean>

例外:

Caused by: org.hibernate.hql.ast.QuerySyntaxException: BOReportTask is not mapped [from BOReportTask r  where r.reportStatus = :status order by r.submissionTimestamp asc]
      at org.hibernate.hql.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:181)
      at org.hibernate.hql.ast.tree.FromElementFactory.addFromElement(FromElementFactory.java:111)
      at org.hibernate.hql.ast.tree.FromClause.addFromElement(FromClause.java:93)
      at org.hibernate.hql.ast.HqlSqlWalker.createFromElement(HqlSqlWalker.java:313)
      at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromElement(HqlSqlBaseWalker.java:3353)
      at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromElementList(HqlSqlBaseWalker.java:3237)
      at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromClause(HqlSqlBaseWalker.java:724)
      at org.hibernate.hql.antlr.HqlSqlBaseWalker.query(HqlSqlBaseWalker.java:575)
      at org.hibernate.hql.antlr.HqlSqlBaseWalker.selectStatement(HqlSqlBaseWalker.java:292)
      at org.hibernate.hql.antlr.HqlSqlBaseWalker.statement(HqlSqlBaseWalker.java:235)
      at org.hibernate.hql.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:254)
      at org.hibernate.hql.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:185)
      at org.hibernate.hql.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:136)
      at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:101)
      at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:80)
      at org.hibernate.engine.query.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:98)
      at org.hibernate.impl.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:156)
      at org.hibernate.impl.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:135)
      at org.hibernate.impl.SessionImpl.createQuery(SessionImpl.java:1760)
      at a.b.c.report.dao.hibernate.table.ReportTaskDao.fetchByStatus(ReportTaskDao.java:68)
4

1 回答 1

2

所以我最近重新发现了这篇文章,并认为我会为后代发布解决方案。在 RAD 中导出 jars 时,jar 向导在向导的第一页上有一个名为“Add Directory Entries”的复选框。检查那个。没有它,将找不到我的 packagesToScan 引用,它指向包含实体的包的根目录(因为有多个实体包)。它表现得好像没有实体。选中此项会将内容添加到清单中,并导致注释扫描仪找到类。

于 2013-12-03T17:01:34.073 回答