много к одной проблеме - PullRequest
       2

много к одной проблеме

0 голосов
/ 23 января 2011

У меня есть эта ошибка в течение нескольких часов, и я больше ее не получаю. Это проект с Spring 2.5 и hibernate3. Я также пытался объявить объект проекта в объекте клиента.

У меня есть 2 таблицы: клиент и проект

CREATE TABLE client (clientId INT NOT NULL,
                     PRIMARY KEY (clientId)
) ENGINE=INNODB;
CREATE TABLE project (projectId INT, clientId INT,
                    INDEX par_ind (clientId),
                    FOREIGN KEY (clientId) REFERENCES client(clientId)
                      ON DELETE CASCADE
) ENGINE=INNODB;

в коде Java:

public class Project implements Serializable {

 private int id;
 private String name;
 private String description;
 private Date startDate;
 private Date endDate;
 private String manager;
 private Client client;

 public Project(String name, Date startDate, Date endDate) {

  this.name = name;
  this.startDate = startDate;
  this.endDate = endDate;
 }

 public int getId() {
  return id;
 }

 public void setId(int id) {
  this.id = id;
 }

 public String getName() {
  return name;
 }

 public void setName(String name) {
  this.name = name;
 }

 public String getDescription() {
  return description;
 }

 public void setDescription(String description) {
  this.description = description;
 }

 public Date getStartDate() {
  return startDate;
 }

 public void setStartDate(Date startDate) {
  this.startDate = startDate;
 }

 public Date getEndDate() {
  return endDate;
 }

 public void setEndDate(Date endDate) {
  this.endDate = endDate;
 }

 public String getManager() {
  return manager;
 }

 public void setManager(String manager) {
  this.manager = manager;
 }

 public Client getClient() {
  return client;
 }

 public void setClient(Client client) {
  this.client = client;
 }

 public String toString() {
  StringBuffer buffer = new StringBuffer();
  buffer.append("Project name: " + name);
  buffer.append("Project description: " + description);
  buffer.append("Project start date: " + startDate);
  buffer.append("Project end date: " + endDate);
  return buffer.toString();
 }

 public boolean equals(Object obj) {
  if ((obj instanceof Project)
    && (((Project) obj).getName() == this.name)) {
   return true;
  }
  return false;
 }

}



public class Client implements Serializable {

 /**
  * 
  */
 private static final long serialVersionUID = 1L;
 private int id;
 private String name;
 private String company;
 private String location;
 private String city;
 private String country;

 public Client() {

 }

 public Client(String name) {
  this.name = name;
 }

 public int getId() {
  return id;
 }

 public void setId(int id) {
  this.id = id;
 }

 public String getName() {
  return name;
 }

 public void setName(String name) {
  this.name = name;
 }

 public String getCompany() {
  return company;
 }

 public void setCompany(String company) {
  this.company = company;
 }

 public String getLocation() {
  return location;
 }

 public void setLocation(String location) {
  this.location = location;
 }

 public String getCity() {
  return city;
 }

 public void setCity(String city) {
  this.city = city;
 }

 public String getCountry() {
  return country;
 }

 public void setCountry(String country) {
  this.country = country;
 }

 public String toString() {
  StringBuffer buffer = new StringBuffer();
  buffer.append("Client name: " + name);
  buffer.append("Client company: " + company);
  buffer.append("Client location: " + location);
  buffer.append("Client city: " + city);
  buffer.append("Client country: " + country);
  return buffer.toString();
 }

 public boolean equals(Object obj) {
  if ((obj instanceof Client) && (((Client) obj).getName() == this.name)) {
   return true;
  }
  return false;
 }

}

В файлах отображения Hibernate у меня есть это:

<hibernate-mapping package="test.domain">
 <class name="Client" table="clients" dynamic-update="true">
  <id name="id" column="clientId" type="integer">
   <generator class="increment" />
  </id>
  <property name="name" column="name" type="string" />
  <property name="company" column="company" type="string" />
  <property name="location" column="location" type="string" />
  <property name="city" column="city" type="string" />
  <property name="country" column="country" type="string" />

 </class>
</hibernate-mapping>

и

<hibernate-mapping package="test.domain">
 <class name="Project" table="project" dynamic-update="true">
  <id name="id" column="projectId" type="integer">
   <generator class="increment" />
  </id>
  <property name="name" column="name" type="string" />
  <property name="description" column="description" type="string" />
  <property name="startDate" column="start_date" type="string" />
  <property name="endDate" column="end_date" type="string" />
  <property name="manager" column="manager" type="string" />

  <!-- a client has many projects -->
  <many-to-one name="client" column="clientId"
   class="test.domain.Client" cascade="save-update" lazy="false" />

 </class>
</hibernate-mapping>

И я получаю эту ошибку:

Caused by: org.hibernate.PropertyNotFoundException: Could not find a getter for description in class test.domain.Client
 at org.hibernate.property.BasicPropertyAccessor.createGetter(BasicPropertyAccessor.java:282)
 at org.hibernate.property.BasicPropertyAccessor.getGetter(BasicPropertyAccessor.java:275)

Путь к этой проблеме, и теперь я даже не знаю, является ли это правильным способом объявления отношений между клиентом и проектом. Вы видите ошибку в коде выше? В любом случае, большое спасибо.

1 Ответ

0 голосов
/ 24 января 2011

Я обнаружил, что проблема была в моем внимании, этот код работал нормально, но в другом файле hbm.xml была ошибка, дублирующее имя Clients вместо требуемого.Я искал не в том месте, это была моя ошибка.Спасибо.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...