Hibernate TABLE не отображается - PullRequest
1 голос
/ 18 августа 2011

Я получаю эту ошибку

11:55:43,125 INFO  [org.hibernate.impl.SessionFactoryObjectFactory] (MSC service thread 1-16) Not binding factory to JNDI, no JNDI name configured
11:55:43,215 ERROR [stderr] (MSC service thread 1-16) org.hibernate.hql.ast.QuerySyntaxException: ServerSettings is not mapped [from ServerSettings as ss]
11:55:43,215 ERROR [stderr] (MSC service thread 1-16)   at org.hibernate.hql.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:181)
11:55:43,215 ERROR [stderr] (MSC service thread 1-16)   at org.hibernate.hql.ast.tree.FromElementFactory.addFromElement(FromElementFactory.java:110)
11:55:43,216 ERROR [stderr] (MSC service thread 1-16)   at org.hibernate.hql.ast.tree.FromClause.addFromElement(FromClause.java:93)

При попытке развернуть мое приложение.

Мой класс называется ServerSettings.java - он выглядит как

static public ServerSettings GetServerSettings() throws Exception
{
    List retList = null;
    ServerSettings ss = null;
    try {
        Session hsession = HibernateUtil.currentSession();
        retList = hsession.createQuery("from ServerSettings as ss").list();
        if (retList == null || retList.size() <= 0)
            return null;
        ss = (ServerSettings) retList.get(0);
    } 
    finally
    {
        HibernateUtil.closeSession();
    }
    return ss;

наш файл persistence.xml выглядит как

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
   xmlns="http://java.sun.com/xml/ns/persistence"         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="
        http://java.sun.com/xml/ns/persistence
        http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
   <persistence-unit name="primary">

  <jta-data-source>java:jboss/datasources/MySqlDS</jta-data-source>
  <properties>
     <!-- Properties for Hibernate -->
     <!-- <sproperty name="hibernate.hbm2ddl.auto" value="create-drop" /> -->
     <!-- <property name="hibernate.show_sql" value="false" /> -->
  </properties>

У нас также есть hibernate.cfg.xml

   <session-factory>
      <property name="datasourceName">java:jboss/datasources/MySqlDS</property>
      <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

   </session-factory>

</hibernate-configuration>

и ServerSettings.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
        <class name="com.mycompanyServerSettings" table="server_settings">
        <id name="serverSettingsID" type="integer" column="server_settings_id"> 
            <generator class="identity" />
        </id>
        <version  name="updateCounter" column="update_counter"/>
        <property name="changedDate" type="timestamp" column="changed_date"/>
        <property name="changedBy" type="string" column="changed_by"/>
        <property name="createdDate" type="timestamp" column="created_date"/>
        <property name="createdBy" type="string" column="created_by"/>
        <property name="status" type="string" column="status"/>

        <property name="defaultJmsQueueName" type="string" column="default_jms_queue_name"   />
        <property name="defaultJmsQueueURL" type="string" column="default_jms_queue_url"   />
        <property name="emailServer" type="string" column="email_server"   />
        <property name="emailFromAddress" type="string" column="email_from_address"   />
        <property name="emailUser" type="string" column="email_user"   />
        <property name="emailPassword" type="string" column="email_password"   />
        <property name="defaultJMSQueueID" type="string" column="default_jms_queue_id"   />
        <property name="useEncryption" type="integer" column="use_encryption"   />

</class>

Обычно эта ошибка возникает при использовании имени таблицы вместо имени класса в hql - но здесь это не так. Также это работало ранее в JBoss AS5 - я перехожу на JBoss AS7. Любой совет?

1 Ответ

3 голосов
/ 18 августа 2011
<class name="com.mycompanyServerSettings"
                          ^-- A dot is missing here

Более того, ServerSettings.hbm.xml не указан в основном файле hibernate.cfg.xml.У вас должен быть такой элемент в элементе session-factory:

<mapping resource="com/mycompany/ServerSettings.hbm.xml"/>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...