当前位置: 首页 > 知识库问答 >
问题:

org.hibernate.MappingException:未知实体:Library.Model.Person

叶越
2023-03-14
@Entity
@Table(name = "PERSON")
public class Person implements Serializable {

// Attributes.    
@Id
@Column(name = "ID", unique = true, nullable = false)    
@GeneratedValue(strategy=GenerationType.AUTO)
private Integer id;

@Column(name = "NAME", nullable = false, length=50)      
private String name;

@Column(name = "ADDRESS", nullable = false, length=100)
private String address;

@Column(name = "TELEPHONE", nullable = false, length=10)
private String telephone;

@Column(name = "EMAIL", nullable = false, length=50)
private String email;

@OneToMany(cascade=CascadeType.ALL, fetch = FetchType.LAZY)
@JoinColumn(name="PERSON_ID")   
private List<Book> books;

// Constructors.
public Person() {
    this.id = 0;
    this.name = ("");
    this.address = ("");
    this.telephone = ("");
    this.email = ("");
    this.books = null;
}

此实体由Spring控制器管理,方法如下:

@RequestMapping(value = "/register", method = RequestMethod.POST)
public String post(@ModelAttribute("person") Person person, 
                   BindingResult bindingResult, 
                   SessionStatus sessionStatus,
                   Model model /* , 
                   HttpSession session */) throws DAOException {                  
    logger.info(PersonController.class.getName() + ".post() method called.");

    personValidator.validate(person, bindingResult);
    if (bindingResult.hasErrors()) {
        return "register";
    }
    else {

        // Write Person to database.
        personService.insert(person);

        // Set view.
        sessionStatus.setComplete();             
        return "options";            
    }
} 

服务类别为:

@Service("personService")
@Transactional
public class PersonService {

@Autowired 
PersonDAO personDAO;

public void insert(Person person) throws DAOException {
    personDAO.insert(person);
}

而DAO是这样的:

@Repository("PersonDAO")
public class PersonDAOImpl implements PersonDAO {

@Autowired
private SessionFactory sessionFactory;
static final Logger logger = Logger.getLogger(PersonDAOImpl.class.getName()); 

@Override
public void insert(Person person) throws DAOException {
    logger.info(PersonDAOImpl.class.getName() + ".insert() method called.");

    Session session = sessionFactory.openSession();
    Transaction transaction = session.getTransaction();
    try {
        transaction.begin();
        session.save(person);
        transaction.commit();
    }
    catch(RuntimeException e) {
        transaction.rollback();
        throw new DAOException(e);
    }
    finally {
        session.close();
    }
}
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource"></property>        
    <property name="hibernateProperties">
        <props>
           <prop key="hibernate.dialect">org.hibernate.dialect.DerbyDialect</prop>
           <prop key="hibernate.show_sql">true</prop>
           <prop key="hibernate.current_session_context_class ">thread</prop>

           <!-- What to do with the database schema. -->
           <prop key="hbm2ddl.auto">validate</prop>    
           <!-- validate:    validate the schema, makes no changes to the database.
                update:      update the schema.
                create:      creates the schema, destroying previous data.
                create-drop: drop the schema at the end of the session. -->                 
        </props>            
    </property>                    
</bean>
org.hibernate.MappingException: Unknown entity: library.model.Person
<property name="packagesToScan" value="library.model" /> 

<property name="annotatedClasses">
        <list>
            <value>library.model.Person</value>
        </list>
    </property>   

共有1个答案

常飞翼
2023-03-14

尝试替换:

<property name="annotatedClasses">
    <list>
        <value>library.model.Person</value>
    </list>
</property>  

与:

<property name="packagesToScan">
   <list>
       <value>library.model</value>
    </list>
</property>

在您的sessionFactory属性中。

<dependency>
   <groupId>org.springframework</groupId>
   <artifactId>spring-orm</artifactId>
   <version>YOUR SPRING VERSION HERE</version>
</dependency>
 类似资料:
  • 问题内容: 我正在尝试入门Hibernate 2nd Edition,而我一直试图将简单的工作示例与HSQLDB结合在一起。 当我跑步时,我得到 这是我得到的: Message.java PopulateMessages.java build.properties hibernate.cfg.xml build.xml 问题答案: 您的实体注释不正确, 必须 使用注释。您可以使用Hibernate

  • 问题内容: 我真的很想了解我的代码发生了什么。 我有一个独立的应用程序,它使用spring和Hibernate作为JPA,我正在尝试使用单个主类运行测试 我的主班 我的应用程序上下文是: 我的用户模型是: 我的DAO是: 这是我运行程序时出现的我的stacktrace错误: 问题答案: 您必须在会话工厂配置中列出您的类。如果使用,则可以自动发现实体。 为了在hibernate和spring中使用注

  • 我在应用程序中使用了Spring3和Hibernate4。在运行时,我得到的异常值低于异常值。

  • 问题内容: 我写了一些代码将数据插入SQL数据库。实际上,我正在尝试使用Hibernate学习Struts2。但是,不幸的是,我在提交表格后遇到了问题。 我找不到此错误消息的原因。我的try&catch块引发如下错误: Pojo(): 还具有: 问题答案: 如果未映射实体,则应检查hibernate配置。Hibernate是ORM框架,用于将pojo(实体)映射到数据库架构对象。您没有配置或hib

  • 查询: 错误: 在我的网上搜索中,几乎所有论坛主题的答案都是一致的:“把@实体放在类声明之前”,但是,这对我来说不起作用。

  • 我有一个测试车, 而applicatin.xml是 但它报告异常 java.lang.IllegalArgumentException:未知实体:com.chinalbs.entity.conductor(位于org.hibernate.ejb.abstractentyManagerImpl.persist(abstractentyManagerImpl.java:842)(位于sun.refle