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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Hibernate, как такое может быть 
V
    Опции темы
Zyamizz
Дата 27.9.2007, 09:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Подскажите, как такое может быть: настроил hibernate, создал простенькую таблицу в MySQL,
чтение из БД идёт нормально, запись не работает. Где копать?

Код

            Session session = HibernateUtil.getSessionFactory().openSession();
            Transaction tx = session.beginTransaction();

            session.save(project); // project не записывается в БД

            tx.commit();


Судя по логам, при чтении создаётся SQL запрос:

Hibernate: 
    select
        project0_.PK as PK0_,
        project0_.Index as Index0_,
        project0_.Name as Name0_,
        project0_.Description as Descript4_0_,
        project0_.Note as Note0_,
        project0_.Manager as Manager0_ 
    from
        PROJECTS project0_

При записи: 

Hibernate: 
    insert 
    into
        PROJECTS
        (Index, Name, Description, Note, Manager, PK) 
    values
        (?, ?, ?, ?, ?, ?)

не подставляются values

Это сообщение отредактировал(а) Zyamizz - 27.9.2007, 09:02
PM MAIL   Вверх
AlexeyVorotnikov
Дата 27.9.2007, 09:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



А где и как создаётся объект project?


--------------------
RTFM!
Три источника и три составные части Java: The Java Language Specification, Java Platform API Specification, The Java Virtual Machine Specification
PM MAIL   Вверх
Zyamizz
Дата 27.9.2007, 09:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



project передаётся в функцию addNewProject как аргумент.

я этот объект проверял, все поля в нём заданы правильно.

Код

import java.io.IOException;
import javax.servlet.*;
import javax.servlet.http.*;
import ru.papillon.man.hibernate.*;
import org.hibernate.*;

public class SaveProject extends HttpServlet {
    private static final long serialVersionUID = 1L;

    public void doPost (HttpServletRequest request,
                        HttpServletResponse response) throws
            ServletException, IOException {
        Project newProject = populateNewProjectFromRequest(request);
        addNewProject(newProject);
        forwardToProjectsView(request, response);
    }
    
    private void addNewProject (Project project) throws
        ServletException, IOException {
        try {
            
            Session session = HibernateUtil.getSessionFactory().openSession();
            Transaction tx = session.beginTransaction();

            session.save(project); ///////////////////////////////////////////////// ERRRORRR!

            tx.commit();
            session.close();

        } catch (Exception ex) {
            getServletContext().log(
                    "Error: ProjectBean.addNewProject()", ex);
        }
    }
    
    private void forwardToProjectsView (HttpServletRequest request,
                                        HttpServletResponse response) 
                throws ServletException, IOException {
        RequestDispatcher dispatcher = request.getRequestDispatcher("/projects");
        dispatcher.forward(request, response);
    }
    
    private Project populateNewProjectFromRequest (HttpServletRequest request) {
        Project newProject = new Project();
        populatePapIndex(request, newProject);
        populateName(request, newProject);
        populateDescription(request, newProject);
        populateNote(request, newProject);
        populateManager(request, newProject);
        return newProject;
    }
    
    private void populatePapIndex (HttpServletRequest request, Project newProject) {
        short papIndex = Short.parseShort(request.getParameter("papIndex"));
        if (request.getParameter("papIndex") != null) newProject.setPapIndex(papIndex);
    }
    
    private void populateName (HttpServletRequest request, Project newProject) {
        String name = request.getParameter("name");
        if (name != null) newProject.setName(name);
    }
    
    private void populateDescription (HttpServletRequest request, Project newProject) {
        String description = request.getParameter("description");
        if (description != null) newProject.setDescription(description);
    }
    
    private void populateNote (HttpServletRequest request, Project newProject) {
        String note = request.getParameter("note");
        if (note != null) newProject.setNote(note);
    }
    
    private void populateManager (HttpServletRequest request, Project newProject) {
        String manager = request.getParameter("manager");
        if (manager != null) newProject.setManager(manager);
    }
}




Это сообщение отредактировал(а) Zyamizz - 27.9.2007, 09:52
PM MAIL   Вверх
tux
Дата 27.9.2007, 10:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



А что за 
Цитата

///////////////////////////////////////////////// ERRRORRR!

можно уже написать? Ошибка вылетает или просто в таблицу ничего не пишется?

Добавлено через 29 секунд
Если исключение, то стэктрейс в студию.
PM MAIL Skype GTalk Jabber YIM   Вверх
Zyamizz
Дата 27.9.2007, 10:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Уфф. Разобрался. Два дня мучался...

Ошибка была в project.hbm.xml.
Забыл что в мускуле названия колонок нужно писать в хитрых `кавычках`

Спасибо всем откликнувшимся за поддержку.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "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.0725 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


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

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