[英]Mapping annotations in Hibernate
When I'm trying to add a new record in Work_orders table I get an error: 当我尝试在Work_orders表中添加新记录时,出现错误:
Dec 09, 2014 8:44:17 PM com.opensymphony.xwork2.util.logging.jdk.JdkLogger warn
WARNING: No configuration found for the specified action: 'saveWorkOrder' in
namespace: ''. Form action defaulting to 'action' attribute's literal value.
I have a simple dao class to save and select records. 我有一个简单的dao类来保存和选择记录。 I use 3 tables and 2 foreign keys. 我使用3个表和2个外键。
WorkOrders.java WorkOrders.java
@Entity
@Table(name="Work_orders", schema="handyman")
public class WorkOrder implements Serializable {
....
@ManyToOne
// @JoinColumn(name = "Companys_list_id")
//@ManyToOne(optional=false)
@JoinColumn(name="Companys_list_id", referencedColumnName="id")
private Company company;
@ManyToOne(optional=false)
@JoinColumn(name="Handymans_list_id", referencedColumnName="id")
private Handyman handyman;
....
getters and setters
WorkOrderDaoHibernate.java WorkOrderDaoHibernate.java
public class WorkOrderDaoHibernate implements Serializable {
private static final long serialVersionUID = 1L;
public WorkOrder saveWorkOrder(WorkOrder workOrder)
{
SessionFactory sf = HibernateUtil.getSessionFactory();
Session session = sf.openSession();
Transaction trans = session.beginTransaction();
Integer id = (Integer) session.save(workOrder);
trans.commit();
workOrder.setId(id);
session.close();
return workOrder;
Hibernate configuration file: 休眠配置文件:
<hibernate-configuration>
<session-factory>
<!-- Database connection settings -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/handyman</property>
<property name="connection.username">root</property>
<property name="connection.password">1982</property>
<!-- JDBC connection pool (use the built-in) -->
<property name="connection.pool_size">5</property>
<!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- Enable Hibernate's automatic session context management -->
<!-- <property name="current_session_context_class">thread</property> -->
<!-- Disable the second-level cache -->
<!-- <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property> -->
<!-- Echo all executed SQL to stdout -->
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<!-- Drop and re-create the database schema on startup -->
<!-- <property name="hbm2ddl.auto">update</property> -->
<mapping class="com.handyman.model.Company" />
<mapping class="com.handyman.model.Handyman" />
<mapping class="com.handyman.model.WorkOrder" />
</session-factory>
在您的HibernateUtil类中,在buildSessionFactory()方法内尝试进行此更改并让我知道会发生什么
configuration= configuration.configure();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.