как подключиться к MySql с Hbernate с помощью Eclipse - PullRequest
0 голосов
/ 11 октября 2011

Я новичок в спящем и затмении.Я успешно сделал это с Дерби, посмотрев видео на YouTube.Теперь я хочу сделать это с MySql.

Мне удалось подключить MySQL к eclips

Далее я написал простой персистентный класс person

import javax.persistence.Entity;import javax.persistence.Id;

@ Открытый класс сущности Person {

private String name;
private int id;


public String getName() {
    return name;
}
public void setName(String name) {
    this.name = name;
}
@Id
public int getId() {
    return id;
}
public void setId(int id) {
    this.id = id;
}

}


Далее я написал тестовый класс для этого

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.tool.hbm2ddl.SchemaExport;


public class PersonTest {

    /**
     * @param args
     */
    public static void main(String[] args) {

        AnnotationConfiguration cfg = new AnnotationConfiguration();
        cfg.addAnnotatedClass(Person.class);
        cfg.configure("hibernate.cfg.xml");

        new SchemaExport(cfg).create(true, true);

        SessionFactory factory = cfg.buildSessionFactory();
        Session session = factory.getCurrentSession();
        session.beginTransaction();

        Person person = new Person();

        person.setName("Alex");
        person.setId(1);

        session.save(cfg);
        session.getTransaction().commit();

    }

}

Мой конфигурационный файл Hibernate

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<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/ruwaKuppi</property>
        <property name="connection.username">root</property>
        <property name="connection.password">1234</property>
        <property name="hibernate.default_schema">ruwaKuppi</property>

        <!-- JDBC connection pool (use the built-in) -->
        <property name="connection.pool_size">2</property>

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="hibernate.hbm2ddl.auto">update</property>
        <mapping resource="person.hbm.xml"/>

    </session-factory>

</hibernate-configuration>

Мой файл сопоставления

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <class name="Person" table="PERSON">
   <id name="id" type="int" column="ID" >
   <generator class="assigned"/>
  </id>

  <property name="name">
   <column name="NAME" />
  </property>

 </class>
</hibernate-mapping>

Теперь я получаю эту ошибку ....! [введите описание изображения здесь] [2]

13: 13: 17,795 ИНФОРМАЦИЯ Версия: 15 - Hibernate Аннотации 3.4.0.GA 13: 13: 17,818 ИНФОРМАЦИЯ Окружающая среда: 560 - Hibernate 3.3.2.GA 13: 13: 17,821 Информационная среда: 593 - hibernate.properties не найден 13: 13: 17,825 Информационная среда: 771 - Имя поставщика байт-кода: javassist 13: 13: 17,830 Информационная среда: 652 - с использованием JDK 1.4 java.sql. Обработка временных меток 13:13: 17,927 Версия INFO: 14 - Hibernate Commons Annotations 3.1.0.GA 13: 13: 17,949 Конфигурация INFO: 1474 - настройка с ресурса: hibernate.cfg.xml 13: 13: 17,950 Конфигурация INFO: 1451 - Ресурс конфигурации: hibernate.cfg.xml 13: 13: 18,059 Конфигурация INFO: 600 - Чтение сопоставлений из ресурса: person.hbm.xml 13: 13: 18,147 Конфигурация INFO: 1589 - Сконфигурированная SessionFactory: null 13: 13: 18,173 Инфо-диалект: 175 - Использование dialect: org.hibernate.dialect.MySQLDialect 13: 13: 18,307 INFO HbmBinder: 322 - Класс сопоставления: Person -> ЛИЦО 13: 13: 18,326 ИНФОРМАЦИЯ AnnotationBinder: 419 - Связывающая сущность из аннотированного класса: Персона 13: 13: 18,364 ИНФОРМАЦИЯ Отображения: 161 - дублирующий импорт: Персона-> Персона 13: 13: 18,367 ИНФО EntityBinder: 422 - Связать сущность Персона наТаблица Исключение Person в потоке "main" org.hibernate.DuplicateMappingException: Двойное сопоставление класса / сущности Person в org.hibernate.cfg.Mappings.addClass (Mappings.java:141) в org.hibernate.cfg.AnnotationBinder.bindClass (AnnotationBinder.Java: 789) в org.hibernate.cfg.AnnotationConfiguration.processArtifactsOfType (AnnotationConfiguration.java:546) в org.hibernate.cfg.AnnotationConfiguration.secondPassCompile (AnnotationConfiguration.java:291Conf..java: 803) в org.hibernate.tool.hbm2ddl.SchemaExport. (SchemaExport.java:128) в org.hibernate.tool.hbm2ddl.SchemaExport. (SchemaExport.java:91) в PersonTest.main (PersonTest.java:18)

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

ps: я знаю, что последний код не ясен .... Я думаю, что это важная строка выше

13: 13: 18,367 INFO EntityBinder: 422 - Связать сущность Person в таблице Person Исключение в потоке "main" org.hibernate.DuplicateMappingException: Дублировать сопоставление класса / сущности Person в org.hibernate.cfg.Mappings.addClass (Mappings.Java: 141)

Ответы [ 3 ]

1 голос
/ 02 декабря 2016

файл класса человека

@Entity public class Person {

private String name;
@Id
private int id;



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

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

}

тестовый класс открытый класс PersonTest {

/**
 * @param args
 */
public static void main(String[] args) {
 Person person = new Person();

    person.setName("Alex");
    person.setId(1);

    SessionFactory factory =  Configuration().configure().buildSessionFactory();
    Session session = factory.openSession();
    session.beginTransaction();
    session.save(person);
    session.getTransaction().commit();

}

}

hibernate.cfg.xml

<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<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/ruwaKuppi</property>
    <property name="connection.username">root</property>
    <property name="connection.password">1234</property>

    <!-- JDBC connection pool (use the built-in) -->
    <property name="connection.pool_size">1</property>

    <!-- SQL dialect -->
    <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

    <!-- Disable the second-level cache  -->
    <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>

    <!-- Echo all executed SQL to stdout -->
    <property name="show_sql">true</property>

    <!-- Drop and re-create the database schema on startup -->
    <property name="hbm2ddl.auto">create</property>

    <!-- Names the annotated entity class -->
    <mapping class="Put your package name and class name here"/>

</session-factory>

</hibernate-configuration>

нет необходимости добавлять файл сопоставления убедитесь, что ваши спящие банки включены в jdbc jar. включить jar из lib-bytecode-javassist, JPA и требуется. проверьте файл hibernate.cfg.xml, он должен быть включен в папку src

1 голос
/ 11 октября 2011

Вы указываете Hibernate загружать сопоставление из файла hibernate.cfg.xml:

cfg.configure("hibernate.cfg.xml");

Но вы также указываете ему добавить класс Person в качестве сущности аннотаций сопоставленного лотка:

cfg.addAnnotatedClass(Person.class);

Решите, хотите ли вы отобразить сущность Person с помощью аннотаций или с использованием XML.Если вы выбрали XML, то удалите строку cfg.addAnnotatedClass(Person.class);.Если вы выберете аннотации, то удалите <class name="Person" table="PERSON"> (и, конечно, все его подэлементы) из файла XML.

0 голосов
/ 05 сентября 2012

Удалить аннотацию '@id' из получателя идентификатора класса Person

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