понимание session.get против метода session.load в спящем режиме - PullRequest
6 голосов
/ 03 августа 2011

Я не могу понять разницу между загрузкой и получением. следующий фрагмент кода не работает, когда я даю session.load. Это дает исключение нулевого указателя. Но то же самое работает, когда я использую session.get ().

public Employee getEmployee(final String id){        
        HibernateCallback callback = new HibernateCallback() {
            public Object doInHibernate(Session session) 
                throws HibernateException,SQLException {
                //return (Employee)session.load(Employee.class, id);   doesn't work
                  return (Employee)session.get(Employee.class, id);    //it works
            }
        };        
        return (Employee)hibernateTemplate.execute(callback);
    }

Я также хочу понять, как объект Session передается в doInHibernate.?
когда начинается сессия и когда она заканчивается?

Трассировка стека выглядит следующим образом

Exception in thread "main" java.lang.NullPointerException
    at org.hibernate.tuple.AbstractEntityTuplizer.createProxy(AbstractEntityTuplizer.java:372)
    at org.hibernate.persister.entity.AbstractEntityPersister.createProxy(AbstractEntityPersister.java:3121)
    at org.hibernate.event.def.DefaultLoadEventListener.createProxyIfNecessary(DefaultLoadEventListener.java:232)
    at org.hibernate.event.def.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:173)
    at org.hibernate.event.def.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:87)
    at org.hibernate.impl.SessionImpl.fireLoad(SessionImpl.java:862)
    at org.hibernate.impl.SessionImpl.load(SessionImpl.java:781)
    at org.hibernate.impl.SessionImpl.load(SessionImpl.java:774)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.springframework.orm.hibernate3.HibernateTemplate$CloseSuppressingInvocationHandler.invoke(HibernateTemplate.java:1282)
    at $Proxy0.load(Unknown Source)
    at hibernate.EmployeeDao$1.doInHibernate(EmployeeDao.java:25)
    at org.springframework.orm.hibernate3.HibernateTemplate.doExecute(HibernateTemplate.java:406)
    at org.springframework.orm.hibernate3.HibernateTemplate.execute(HibernateTemplate.java:339)
    at hibernate.EmployeeDao.getEmployee(EmployeeDao.java:29)
    at hibernate.SpringHibernateTest.main(SpringHibernateTest.java:26)

1 Ответ

9 голосов
/ 03 августа 2011
I am not able to understand the difference between load and get 

Основное отличие заключается в следующем: если load () не может найти объект в кеше или базе данных, возникает исключение. Метод load () никогда не возвращает ноль. Метод get () возвращает ноль, если объект не может быть найден. Другое отличие состоит в том, что метод load () может возвращать прокси вместо реального экземпляра, но get () никогда не возвращает прокси.

the following piece of code doesn't work when i give session.load. It gives null pointer exception. But same does work when i am using session.get() .

Если объект не найден, метод load выдаст исключение, но get не будет. Простой

Edit: Чтобы разработать вещи,

  1. Когда вызывается метод get (), он напрямую попадает в базу данных, извлекает результат и возвращает результат. Если подходящие поля не найдены, он с удовольствием вернет ноль.

  2. Но когда load () выполняется, сначала он будет искать в кеше нужный объект. Если найден, все хорошо. Но если объект не найден в кеше, метод load () вернет прокси. Вы можете рассматривать этот прокси как ярлык для выполнения запроса к базе данных. Помните, что попадание в базу данных еще не сделано. Теперь, когда вы на самом деле получите доступ к объекту, прокси будет отслеживаться, и будет произведено попадание в базу данных.

Давайте рассмотрим простой пример.

User user=(User)session.load(User.class, new Long(1));//Line 1
System.out.println(user.getPassword());//Line 2

Если объект User с первичным ключом 1 недоступен в сеансе, метод load () установит прокси для базы данных в строке 1. Теперь, когда вызывается фактическое значение объекта 'user', то есть строка 2, прокси будет отслежен, и база данных будет поражена.

Надеюсь, это поможет.

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