Как решить эту исключительную ситуацию NullPointerException, возникающую из метода find (String query) HibernateTemplate - PullRequest
0 голосов
/ 26 марта 2020

Как мне разрешить это исключение NullPointerException? Немного предыстории, я разрабатываю проект на основе Spring и использую HibernateTemlate в слое DAO для выполнения всех операций, связанных с базой данных.

Здесь приведен фрагмент кода, который я извлек из моего тестового класса, который выбрасывает исключение NullPointerException.


   try {
                   List<Object[]> list = (List<Object[]>) ht.find("select uomId,uomModel from in.nit.model.Uom");
                   System.out.println(list);
               }catch(NullPointerException e) {
                   e.printStackTrace();
               }

И это трассировка стека исключений на консоли.

```
java.lang.NullPointerException
    at in.nit.dao.impl.UomDaoImplTest.test(UomDaoImplTest.java:28)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:567)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:56)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
    at org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)
    at org.junit.runners.BlockJUnit4ClassRunner$1.evaluate(BlockJUnit4ClassRunner.java:100)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:366)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:103)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:63)
    at org.junit.runners.ParentRunner$4.run(ParentRunner.java:331)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:79)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:329)
    at org.junit.runners.ParentRunner.access$100(ParentRunner.java:66)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:293)
    at org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:413)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:89)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:41)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:542)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:770)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:464)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:210)
```

Here is my model class

```
@Entity
@Table(name="uomtab")
public class Uom {

    @Id @GeneratedValue @Column(name="umid") private Integer uomId;
    @Column(name="utype") private String uomType;
    @Column(name="umodel") private String uomModel;
    @Column(name="udesc") private String uomDesc;

    public Uom() {
        super();
    }

    public Uom(Integer uomId) {
        this.uomId = uomId;
    }

    public Integer getUomId() {
        return uomId;
    }
    public void setUomId(Integer uomId) {
        this.uomId = uomId;
    }
    public String getUomType() {
        return uomType;
    }
    public void setUomType(String uomType) {
        this.uomType = uomType;
    }
    public String getUomModel() {
        return uomModel;
    }
    public void setUomModel(String uomModel) {
        this.uomModel = uomModel;
    }
    public String getUomDesc() {
        return uomDesc;
    }
    public void setUomDesc(String uomDesc) {
        this.uomDesc = uomDesc;
    }
    @Override
    public String toString() {
        return "Uom [uomId=" + uomId + ", uomType=" + uomType + ", uomModel=" + uomModel + ", 
      uomDesc=" + uomDesc + "]";
    }
}

```

Кроме того, несмотря на то, что метод find (String Query) устарел, я широко использовал его в других Дао классы моего проекта, который работает гладко и хорошо.

Какие могут быть возможные причины этого исключения взорвать мой код?

Ответы [ 2 ]

0 голосов
/ 26 марта 2020

ваша ошибка в классе "UomDaoImplTest". Это не имеет отношения к Hibernate Template. Вы можете опубликовать свой тестовый класс.

0 голосов
/ 26 марта 2020
  1. Вы не должны ловить это NullPointerException
  2. Что такое строка 28 в вашем коде?
  3. Вы пытались отладить строку? Если это строка ht.find, единственное, что имеет смысл, это то, что ваш HibernateTemplate имеет значение null и не был установлен правильно.
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...