Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как сохранить сущность в JPA? 
:(
    Опции темы
oson
Дата 5.5.2012, 14:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 289
Регистрация: 3.3.2004
Где: Севастополь

Репутация: нет
Всего: 1



Подскажите пожалуйста. 
Есть приложение, которое использует Spring webflow + JPA на базе Hibernate. 
Есть такая сущность 

Код:
Код

@Entity
@Table(name = "SUPER_ADMINS")
public class SuperAdmin implements Serializable
{
    private static final long serialVersionUID =1212121232423453452L;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    private String login;
    private String password;
    private String name;



Есть сервис который его сохраняет в базу 


Код

@Service("superAdminService")
@Repository
public class JPASuperAdminService implements SuperAdminService, Serializable
{
    private static final long serialVersionUID = 1L;
    private final static Logger logger = LoggerFactory.getLogger(JPASuperAdminService.class);

    private EntityManager em;

    @PersistenceContext
    public void setEntityManager(EntityManager em)
    {
        this.em = em;
    }

    public void createFlows()
    {
        try
        {
            Query query = em.createQuery("select  sa from SuperAdmin sa where sa.login = :login");
            query.setParameter("login","GOLD");
            List<SuperAdmin> superAdmins = query.getResultList();
            for(SuperAdmin  superAdmin : superAdmins)
            {
                System.out.println(superAdmin.getLogin());
            }

            EnterpriseFlow enterpriseFlow = new EnterpriseFlow("Registration-customer-flow");
            em.persist(enterpriseFlow);

        }
        catch (Exception e)
        {
            e.printStackTrace();
        }

    }
}



Первую часть специально сделал, чтобы увидеть, есть ли select из базы 
В консоли Томката select выводится. 

Код

Hibernate: select superadmin0_.id as id3_, superadmin0_.login as login3_, superadmin0_.name as name3_, superadmin0_.password as password3_ from SUPER_ADMINS superadmin0_ where superadmin0_.login=? 



То есть доступ к базе есть и select выполняется. 

А на момент, когда должен отработать em.persist(enterpriseFlow), выводится только вот это 


Код

Hibernate: select nextval ('hibernate_sequence')




и никаких insert. 

Вроде бы достаточно достаточно em.persist(entity) ? Или чего то не хватает, чтобы сохранить сущность в базе?
PM MAIL   Вверх
Stolzen
Дата 5.5.2012, 15:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1041
Регистрация: 17.10.2005

Репутация: 3
Всего: 48



Чтобы сохранить сущность в базе нужно сделать flush на сессии. Он автоматически делается при коммите.


--------------------
datatalks.ru - анализ данных, статистика, машинное обучение
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.0693 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.