Как я могу вставить новую строку в таблицу, используя Hibernate? - PullRequest
0 голосов
/ 06 марта 2019

Я пытаюсь понять JPA / Hibernate, я могу создать новую базу данных, но я не понимаю, как вставить новую строку в мой база данных. Это код:

import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Person implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    private String name;
    private String adress;
    private String phoneNumber;

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

    public void setAdress(String adress) {
        this.adress = adress;
    }

    public void setPhoneNumber(String phoneNumber) {
        this.phoneNumber = phoneNumber;
    }

    public String getName() {
        return name;
    }

    public String getAdress() {
        return adress;
    }

    public String getPhoneNumber() {
        return phoneNumber;
    }

    public Long getId() {
        return id;
    }

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

   @Override
    public int hashCode() {
        int hash = 0;
        hash += (id != null ? id.hashCode() : 0);
        return hash;
    }

    @Override
    public boolean equals(Object object) {
        // TODO: Warning - this method won't work in the case the id fields are not set
        if (!(object instanceof Person)) {
            return false;
        }
        Person other = (Person) object;
        if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "entinty.Person[ id=" + id + " ]";
    }


}

Класс, который создает базу данных:

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;

public class Main {

    public static void main(String args[]) {

        Person p = new Person();
        p.setName("xxx");
        p.setAdress("yyy");
        p.setPhoneNumber("zzz");
        EntityManagerFactory emf = javax.persistence.Persistence.createEntityManagerFactory("testPU");
        EntityManager em = emf.createEntityManager();
        em.getTransaction().begin();
        try {
            em.persist(p);
            em.getTransaction().commit();
        } catch (Exception e) {
            e.printStackTrace();
            em.getTransaction().rollback();
        }

        em.close();
        emf.close();



    }

}

На данный момент у меня есть таблица с одной строкой (с надписью "xxx-yyy-zzz"). Как я могу добавить новую строку? Создание нового Person не работает, потому что оно создает новую таблицу ... Я нахожу решение только с использованием Session и SessionFactory, но не могу его использовать, потому что не могу понять, как создать файл hibernate.cfg.xml (и в В общем, как создать объект сеанса). Есть ли решение с использованием только EntityManager? Или как мне сгенерировать / записать файл hibernate.cfg.xml? Есть ли способ автоматически сгенерировать его с помощью netbeans?

РЕДАКТИРОВАТЬ: это мой файл persistence.xml. Где я должен положить? Я положил его в зону ***, но она не работает ...

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
  <persistence-unit name="testPU" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <class>test.Person</class>
    <properties>
      <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/stackoverflow?zeroDateTimeBehavior=convertToNull"/>
      <property name="javax.persistence.jdbc.user" value="root"/>
      <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
      <property name="javax.persistence.jdbc.password" value="leonida95."/>
      <property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider"/>
      <property name="javax.persistence.schema-generation.database.action" value="create"/>
    *****
    </properties>
  </persistence-unit>
</persistence>

1 Ответ

0 голосов
/ 06 марта 2019

Внутри файла Persistance Unit у вас будет что-то вроде

<properties>
   <property name="hibernate.connection.url" value="..." />
   <property name="hibernate.connection.driver_class" value="..."/>
   ...
</properties>

Чтобы создать таблицы при построении EntityManagerFactory, просто добавьте

<property name="hibernate.hbm2ddl.auto" value="create" />

Ваш код работает нормально.
Вы можете вызывать persist столько раз, сколько захотите, и это добавит строки в целевую таблицу.

em.persist(person1);
em.persist(person2);
...

persist не создает таблицу.

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