1

我正在学习 Spring MVC,并尝试使用休眠连接到数据库。MVC 部分工作,在一个单独的项目中,我还可以连接并使用 Derby 数据库。但是当我试图将两者结合起来时,我失败了。

根本原因:

java.lang.NoClassDefFoundError: org/apache/derby/jdbc/ClientDriver
hu.pikk.controller.PikkController.test(PikkController.java:42)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:606)
org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219

我不明白为什么会这样,因为我在 maven 文件中放入了 derby 依赖项:

<dependency>
    <groupId>org.apache.derby</groupId>
    <artifactId>derby</artifactId>
    <version>10.10.1.1</version>
</dependency>

我还将 derbyclient.jar 文件放到了我的类路径中:

..Java\jdk1.7.0_45\db\lib\derbyclient.jar

如果有人有任何想法,为什么找不到课程,我很高兴知道!我试图在 google 和 stackoverflow 上搜索类似的错误,但没有一个答案是有用的。

我试图以不同的方式在我的控制器类中创建一个实体管理器:

@RequestMapping(value={"/","/test"},method = RequestMethod.GET)
public String test(ModelMap model) {
    try {
        DriverManager.registerDriver(new org.apache.derby.jdbc.ClientDriver());
    } catch (SQLException e) {
        e.printStackTrace();
    }
    ClientDriver driver = new ClientDriver();

//  factory = Persistence.createEntityManagerFactory("punit"); //Specified JDBC Driver org.apache.derby.jdbc.ClientDriver could not be loaded

//  manager = factory.createEntityManager();
//  HibernatePersistence hp = new HibernatePersistence();
//  factory = hp.createEntityManagerFactory("persistence.xml",null);
    if(factory!=null){
        manager = factory.createEntityManager();
    }else{
        System.out.println( "### FACTORY IS NULL ### ");
    }

    //manager.getTransaction().begin();
    //Employee first = manager.find(Employee.class, 1);
    //manager.getTransaction().commit();
    //model.addAttribute("employee", first);
    if(manager==null){
        model.addAttribute("message", "Persistence manager is NULL");
    }else{
        model.addAttribute("message", "Persistence manager is not NULL! Hurray!");
    }

    return "test";
}

4

1 回答 1

3

您将需要 derby 客户端的依赖项

<dependency>
    <groupId>org.apache.derby</groupId>
    <artifactId>derbyclient</artifactId>
    <version>10.10.1.1</version>
</dependency>

您还需要确保它在您的容器中可用。您可能希望遵循涵盖数据访问的 Web MVC 春季教程

编辑

我不会混合依赖解析。如果您使用的是 Maven,请坚持使用它。通常将依赖项标记provided为您的容器会将 jar 作为其设置的一部分进行部署。例如,如果您的容器是 Tomcat,您可以将 jar 放入$TOMCAT_HOME/lib

您还应该注意 Spring 提供了 Factory Beans 来创建 Session Factory。会话工厂反过来使用数据源来获取它的连接。通过以这种方式连接 bean,连接管理变得透明,您可以从应用程序中删除该代码。

在典型的 n 层应用程序中,数据访问实现的细节被封装在存储库/DAO 层中,然后从服务层访问该层。服务层捕获业务逻辑并协调数据输入/检索。

您的控制器应该只关心在传递给服务层之前捕获/验证输入,并以客户端期望的格式(HTML、JSON、XML 等)返回输出

于 2013-11-05T10:51:34.010 回答