#java #spring-boot #hibernate #one-to-many #many-to-one
Вопрос:
Я пытаюсь завершить приведенный ниже проект по обновлению базы данных с отношением «один ко многим» и «многие к одному», используя аннотацию hibernate и java без файла hbm. где у одного пользователя может быть несколько ноутбуков. мой проект отлично работает с NetBeans, eclipse. как бы то ни было, вышеприведенная ошибка в веб-среде разработки. я что-то упускаю в коде.
Сущность пользователя-:
@Entity
public class User {
@Id
private int id;
private String first_name;
private String last_name;
private String email;
@OneToMany(targetEntity = Laptop.class, mappedBy = "User", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
private List<Laptop> laptop = new ArrayList<Laptop>();
public User(int id, String first_name, String last_name, String email, List<Laptop> laptop) {
super();
this.id = id;
this.first_name = first_name;
this.last_name = last_name;
this.email = email;
this.laptop = laptop;
}
public List<Laptop> getLaptop() {
return laptop;
}
public void setLaptop(List<Laptop> laptop) {
this.laptop = laptop;
}
public User(int id, String first_name, String last_name, String email) {
super();
this.id = id;
this.first_name = first_name;
this.last_name = last_name;
this.email = email;
}
@Override
public String toString() {
return "Student [id=" id ", first_name=" first_name ", last_name=" last_name ", email=" email
", laptop=" laptop "]";
}
public User(String first_name, String last_name, String email) {
super();
this.first_name = first_name;
this.last_name = last_name;
this.email = email;
}
public User() {
super();
// TODO Auto-generated constructor stub
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getFirst_name() {
return first_name;
}
public void setFirst_name(String first_name) {
this.first_name = first_name;
}
public String getLast_name() {
return last_name;
}
public void setLast_name(String last_name) {
this.last_name = last_name;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
}
Сущность ноутбука-:
@Entity
public class Laptop {
@Id
private int laptop_id;
private String laptop_name;
@ManyToOne
@JoinColumn(name = "user_id", referencedColumnName = "id") //, nullable = false
private User User;
public User getUser() {
return User;
}
public Laptop() {
super();
}
public void setUser(User user) {
this.User = user;
}
public int getId() {
return laptop_id;
}
public void setId(int id) {
this.laptop_id = id;
}
public String getLaptop_name() {
return laptop_name;
}
public void setLaptop_name(String laptop_name) {
this.laptop_name = laptop_name;
}
public Laptop(int id, String laptop_name) {
super();
this.laptop_id = id;
this.laptop_name = laptop_name;
}
@Override
public String toString() {
return "Laptop [id=" laptop_id ", laptop_name=" laptop_name ", user=" User "]";
}
}
мой тестовый класс -:
@Transactional
public class user {
private Session session= null;
@Before
public void before() {
Configuration config = new Configuration().configure().addAnnotatedClass(User.class)
.addAnnotatedClass(Laptop.class);
SessionFactory factory = config.buildSessionFactory();
session = factory.openSession();
}
@org.junit.Test
public void test1() throws Exception{
//LaptopRepository lr;
User user = new User(100,"Escofe","Labro","Escofe@Labro");
Laptop laptop = new Laptop(2,"MACbookPro");
laptop.setUser(user);
user.getLaptop().add(laptop);
Transaction tx = session.beginTransaction();
session.save(user);
session.save(laptop);
tx.commit();
assertEquals("MACbookPro", laptop.getLaptop_name());
}
@org.junit.Test
public void test2() throws Exception{
//LaptopRepository lr;
User user = new User(100,"Anushka","Shetty","anushka@gmali.in");
Laptop laptop = new Laptop(1,"DELLXPS");
laptop.setUser(user);
user.getLaptop().add(laptop);
Transaction tx = session.beginTransaction();
session.save(user);
session.save(laptop);
tx.commit();
assertEquals("Anushka", user.getFirst_name());
assertEquals("DELLXPS", laptop.getLaptop_name());
}
}
Пожалуйста, обратите внимание на несколько вещей, прежде чем вносить какие-либо изменения -:
1> мой hibernate.cfg.xml находится в папке src>
2> Я пробовал настроить («hibernate.cfg.xml») даже полный путь >
3> мой проект отлично работает в среде IDE, такой как NetBeans и eclipse, не работает в веб-среде ide
Пожалуйста, помогите мне, если я что-то упускаю
Комментарии:
1. Вы используете Spring Boot зачем вы создаете SessionFactory в своем тесте?
2. Насколько мне известно, я это сделал. Я буду признателен за любое предложение лучшего способа сделать это. Однако моя проблема не в этом. тест также работает нормально, так как он выдает ошибку в веб-среде IDE (org.hibernate.internal.util.config. Исключение конфигурации: Не удалось найти cfg.xml ресурс [hibernate.cfg.xml])
3. Вам следует прочитать учебник spring.io/guides/gs/accessing-data-jpa
Ответ №1:
Поскольку вы уже перепробовали так много решений для своей проблемы, но они не сработали для вашего проекта. Поэтому я немного делюсь тем, что вы можете сделать. Пожалуйста, проверьте, может ли это помочь…
1> переместите файл конфигурации в основную папку проекта, а затем укажите путь к настройке(«hibernate.cfg.xml») если ошибка броска, проверьте в сообщении об ошибке, какой путь он принимает по умолчанию (сообщение об ошибке покажет вам путь вместе с ошибкой). попробуйте указать полный путь, если он не используется по умолчанию. также попробуйте ниже указать путь ссылки как …
File f = new File(""hibernate.cfg.xml"");
Configuration config = new Configuration().configure(f).addAnnotatedClass(User.class)
.addAnnotatedClass(Laptop.class);
иногда это срабатывает 🙂
2> Попробуйте проверить готовность базы данных с помощью конфигурации java без hibernate.cfg.xml файл. вы можете попробовать, как показано ниже.. (ниже на основе данных mysql chnage при использовании любой другой базы данных)
Configuration cfg = new Configuration()
.addAnnotatedClass(your clas)
.addAnnotatedClass(your clas)
.setProperty("hibernate.dialect", "org.hibernate.dialect.MySQL5Dialect")
.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver")
.setProperty("hibernate.connection.url", "jdbc:mysql://localhost:3306/yourdb")
.setProperty("hibernate.connection.username", "your username")
.setProperty("hibernate.connection.password", "your password")
.setProperty("hibernate.hbm2ddl", "create")
.setProperty("hibernate.show_sql", "true");
cfg.configure();
SessionFactory sf = cfg.buildSessionFactory();
Session session = sf.openSession();
Transaction tx = session.beginTransaction();
здесь, по крайней мере, вы получите представление о своей проблеме.
надеюсь, это поспособствует решению вашей проблемы.
Комментарии:
1. Спасибо, чувак … наконец-то нашел первопричину, и она сработала. попробовал без cfg.xml.