Я новичок в Spring и хотел бы создать небольшой успокоительный API на основе весенней загрузки.
Я настроил базу данных mysql и успешно подключился к своему проекту. Хотя у меня возникли проблемы с установлением отношений между сущностями.
package ca.mcmcaster.xb3l02g06.DineSafeChicago.inspection;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import ca.mcmcaster.xb3l02g06.DineSafeChicago.restaurant.Restaurant;
@Entity
public class Inspection {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "inspection_id")
private Long id;
// @ManyToOne
// @JoinColumn(name="restaurant_id")
// private Restaurant restaurant;
private String result;
private String violation;
private Date time;
@Override
public String toString() {
return "Inspection [result=" + result + ", time=" + time + "]";
}
protected Inspection() {
}
public Inspection(String result, String violation, String timeStr) {
this.result = result;
this.violation = violation;
this.time = parseTime(timeStr);
}
// public void setRestaurant(Restaurant restaurant) {
// this.restaurant = restaurant;
// }
public String getResult() {
return result;
}
public String getViolation() {
return violation;
}
public Date getTime() {
return time;
}
private Date parseTime(String dateStr) {
SimpleDateFormat parser = new SimpleDateFormat("MM/dd/yyyy");
Date time = null;
try {
time = parser.parse(dateStr);
} catch (ParseException e) {
System.out.println("Unparseable using " + dateStr);
}
return time;
}
}
Для каждого ресторана я бы хотел провести множество проверок, связанных с этим.
package ca.mcmcaster.xb3l02g06.DineSafeChicago.restaurant;
import java.util.List;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import ca.mcmcaster.xb3l02g06.DineSafeChicago.inspection.Inspection;
@Entity
public class Restaurant implements Comparable<Restaurant> {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "restaurant_id")
private Long id;
private String name;
private int zip;
private double latitude;
private double longitude;
// private ArrayList<Inspection> inspections;
// private ArrayList<Crime> crimes;
private double foodSafetyScore;
private double neighborhoodSafetyScore;
private double overallScore;
private boolean closed;
// @OneToMany(mappedBy = "restaurant", cascade = CascadeType.ALL,targetEntity = Inspection.class)
// private List<Inspection> inspections;
protected Restaurant() {
}
public Restaurant(String name, int zip, double latitude, double longitude) {
this.name = name;
this.zip = zip;
this.latitude = latitude;
this.longitude = longitude;
this.closed = false;
this.foodSafetyScore = 0;
this.neighborhoodSafetyScore = 0;
}
// public void addInspection(Inspection ins) {
// inspections.add(ins);
// ins.setRestaurant(this);
// }
// public List<Inspection> getInspections() {
// return inspections;
// }
public String getName() {
return name;
}
public int getZip() {
return zip;
}
public double getLatitude() {
return latitude;
}
public double getLongitude() {
return longitude;
}
public double getNeighborhoodSafetyScore() {
return neighborhoodSafetyScore;
}
public double getOverallScore() {
return overallScore;
}
public boolean isClosed() {
return isClosed();
}
public int compareTo(Restaurant other) {
return Double.compare(overallScore, other.overallScore);
}
@Override
public String toString() {
return "Restaurant [name=" + name + ", overallScore=" + overallScore + "]";
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Restaurant other = (Restaurant) obj;
if (id != other.id)
return false;
if (Double.doubleToLongBits(latitude) != Double.doubleToLongBits(other.latitude))
return false;
if (Double.doubleToLongBits(longitude) != Double.doubleToLongBits(other.longitude))
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
if (zip != other.zip)
return false;
return true;
}
}
Я хочу сделать быстрый тест (вставить некоторые данные в БД) следующим образом:
package ca.mcmcaster.xb3l02g06.DineSafeChicago.inspection;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import ca.mcmcaster.xb3l02g06.DineSafeChicago.restaurant.Restaurant;
import ca.mcmcaster.xb3l02g06.DineSafeChicago.restaurant.RestaurantRepository;
@SpringBootApplication
public class Gen implements CommandLineRunner {
@Autowired
private InspectionRepository inspectionRepo;
@Autowired
private RestaurantRepository restaurantRepo;
public static void main(String[] args) {
SpringApplication.run(Gen.class, args);
}
// @Bean
// public CommandLineRunner demo(InspectionRepository repository) {
// return (args) -> {
// Inspection i1 = new Inspection("pass", "no comment", "11/04/1998");
// Inspection i2 = new Inspection("pass with condition", "no comment", "11/04/2019");
// Inspection i3 = new Inspection("fail", "no comment", "11/04/2001");
// repository.save(i1);
// repository.save(i2);
// repository.save(i3);
// System.out.println("All saved!");
// for (Inspection ins : repository.findAll()) {
// System.out.println(ins);
// }
//// Restaurant r1 = new Restaurant("asd", 100, 12.2, 12.2);
// };
// }
@Override
public void run(String[] args) throws Exception {
Restaurant r1 = new Restaurant("asd", 100, 12.2, 12.2);
Inspection i1 = new Inspection("pass", "no comment", "11/04/1998");
Inspection i2 = new Inspection("pass with condition", "no comment", "11/04/2019");
// r1.addInspection(i1);
// r1.addInspection(i2);
restaurantRepo.save(r1);
}
}
Однако я меняю код, просматривая все ответы,
Я всегда получаю сообщение об ошибке при запуске моего весеннего приложения:
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaConfiguration.class]: Invocation of init method failed; nested exception is org.hibernate.AnnotationException: @OneToOne or @ManyToOne on ca.mcmcaster.xb3l02g06.DineSafeChicago.inspection.Inspection.restaurant references an unknown entity: ca.mcmcaster.xb3l02g06.DineSafeChicago.restaurant.Restaurant
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1762) ~[spring-beans-5.1.5.RELEASE.jar:5.1.5.RELEASE]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:593) ~[spring-beans-5.1.5.RELEASE.jar:5.1.5.RELEASE]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:515) ~[spring-beans-5.1.5.RELEASE.jar:5.1.5.RELEASE]
at org.springframework.beans.factory.support.AbstractBeanFactory.lamb
......
Caused by: org.hibernate.AnnotationException: @OneToOne or @ManyToOne on ca.mcmcaster.xb3l02g06.DineSafeChicago.inspection.Inspection.restaurant references an unknown entity: ca.mcmcaster.xb3l02g06.DineSafeChicago.restaurant.Restaurant
at org.hibernate.cfg.ToOneFkSecondPass.doSecondPass(ToOneFkSecondPass.java:97) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processEndOfQueue(InFlightMetadataCollectorImpl.java:1827) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processFkSecondPassesInOrder(InFlightMetadataCollectorImpl.java:1771) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processSecondPasses(InFlightMetadataCollectorImpl.java:1658) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:287) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.metadata(EntityManagerFactoryBuilderImpl.java:904) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
Очень ценю любые полезные советы!