Данные не вставляются с помощью спящего режима, но не выдает ошибку? - PullRequest
4 голосов
/ 13 декабря 2010

Я пытаюсь начать работу с Hibernate, но по какой-то причине не могу вставить данные. Кажется, он работает правильно, так как ошибки не выдается, но когда я проверяю базу данных, таблица пуста. Я не думаю, что происходит сбой подключения к самой базе данных, потому что, когда я меняю имя таблицы на несуществующее в отображающем xml, Hibernate создает это на лету (но, как я уже сказал, данные не вставляются) , Кто-нибудь знает, в чем может быть проблема?

Вот мой код:

hibernate.cfg.xml:

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

<hibernate-configuration>
    <session-factory>
          <property     name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
          <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/intex</property>
          <property name="hibernate.connection.username">root</property>
          <property name="hibernate.connection.password"></property>
          <property name="hibernate.connection.pool_size">10</property>
          <property name="show_sql">true</property>
          <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
          <property name="hibernate.hbm2ddl.auto">update</property>
          <!-- Mapping files -->
          <mapping resource="intex.hbm.xml"/>
    </session-factory>
</hibernate-configuration>

Мое сопоставление xml:

<hibernate-mapping>
  <class name="com.intex.uni.courses.Course" table="course">
   <id name="id" column="id" >
   <generator class="increment"/>
  </id>

  <property name="name" column="name" />
  <property name="description" column="description" />
  <property name="url" column="url" />
  <property name="code" column="code" />
 </class>
</hibernate-mapping>

И мой тестовый клиент:

public class HibernateTest {

    public static void main(String[] args) {

        Session session = null;

        try {
            SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
            session = sessionFactory.openSession();
            Course course = new Course();
            course.setDescription("Description");
            course.setName("NAME");
            course.setUrl("http://www.url.com");
            session.save(course);
        } catch (Exception e) {
            System.out.println(e.getMessage());
        } finally {
            session.flush();
            session.close();
        }
    }
}

Я очень надеюсь, что кто-нибудь сможет мне помочь! Заранее спасибо:)

Ответы [ 5 ]

5 голосов
/ 14 декабря 2010

используйте этот код и тестируйте в основном классе.

Session session = null;
Transaction txn = null;
try {  
    SessionFactory sessionFactory = 
        new Configuration().configure().buildSessionFactory();
    session = sessionFactory.openSession();  
    txn = session.beginTransaction();
    Course course = new Course();  
    course.setDescription("Description");
    course.setName("NAME");
    course.setUrl("http://www.url.com"); 
    session.save(course); 
    txn.commit();

} catch (Exception e) { 
    System.out.println(e.getMessage());
} finally {
    if (!txn.wasCommitted()) {
        txn.rollback();
    }

    session.flush();  
    session.close();   
}
5 голосов
/ 13 декабря 2010

Я подозреваю, что система не фиксирует транзакцию, которая включает необходимую вставку.Я всегда устанавливаю транзакции явно, например, Пример учебника по началу работы с Hibernate 2.5

Альтернативой является то, что вы должны иметь возможность устанавливать режим фиксации Hibernate в своем коде, чтобы транзакции были неявными - посмотрите FlushMode

0 голосов
/ 07 февраля 2019

Проверить файл сопоставления, если определен какой-либо генератор. закомментируйте генератор и проверьте. Это решение сработало для меня.

0 голосов
/ 08 июля 2013

Пожалуйста, начните транзакцию перед сохранением и подтвердите транзакцию после сохранения.

0 голосов
/ 27 октября 2012

Попробуйте следующий код:

public class HibernateTest {

    public static void main(String[] args) {

        Session session = null;
        Transaction txn = null;
        try {
            SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
            session = sessionFactory.openSession();
            txn = session.beginTransaction();
            Course course = new Course();
            course.setDescription("Description");
            course.setName("NAME");
            course.setUrl("http://www.url.com");
            session.save(course);
            txn.commit();
        } catch (Exception e) {
            System.out.println(e.getMessage());
        } finally {
            session.flush();
            session.close();
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...