- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习 Spring MVC,并尝试使用 hibernate 连接到数据库。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
如果有人有任何想法,为什么找不到类(class),我很乐意知道!我尝试在 google 和 stackoverflow 上搜索类似的错误,但没有一个有用的答案。
我尝试以不同的方式在我的 Controller 类中创建一个实体管理器:
@RequestMapping(value={"/","/test"},method = RequestMethod.GET)
公共(public)字符串测试(ModelMap 模型){
尝试 {
DriverManager.registerDriver(new org.apache.derby.jdbc.ClientDriver());
} catch (SQLException e){
e.printStackTrace();
}
ClientDriver 驱动程序 = new ClientDriver();
//factory = Persistence.createEntityManagerFactory("punit");//无法加载指定的 JDBC Driver org.apache.derby.jdbc.ClientDriver
//manager = factory.createEntityManager();
//HibernatePersistence hp = new HibernatePersistence();
//factory = hp.createEntityManagerFactory("persistence.xml",null);
如果(工厂!=空){
manager = factory.createEntityManager();
}别的{
System.out.println( "### FACTORY 为 NULL ### ");
}
//manager.getTransaction().begin();
//员工优先 = manager.find(Employee.class, 1);
//manager.getTransaction().commit();
//model.addAttribute("员工", first);
如果(经理==空){
model.addAttribute("message", "Persistence manager is NULL");
}别的{
model.addAttribute("message", "Persistence manager is not NULL! Hurray!");
}
返回“测试”;
}
最佳答案
您需要 derby 客户端的依赖项
<dependency>
<groupId>org.apache.derby</groupId>
<artifactId>derbyclient</artifactId>
<version>10.10.1.1</version>
</dependency>
您还需要确保它在您的容器中可用。你不妨关注一个spring tutorial for web MVC that covers data access
编辑
我不会混合依赖解析。如果您正在使用 Maven,请坚持使用它。通常将依赖项标记为 provided
,因为您的容器会将 jar 作为其设置的一部分进行部署。例如,如果您的容器是 Tomcat,您可以将 jar 放在 $TOMCAT_HOME/lib
您还应该注意到 Spring 为 create a Session Factory 提供了工厂 Bean . session 工厂反过来使用数据源来获取它的连接。通过以这种方式连接 bean,连接管理变得透明,您可以从应用程序中删除该代码。
在典型的 n 层应用程序中,数据访问实现的细节被封装在 Repository/DAO 层中,然后从服务层访问该层。服务层捕获业务逻辑并协调数据输入/检索。
您的 Controller 应该只关心在传递到服务层之前捕获/验证输入,并以客户端期望的格式(HTML、JSON、XML 等)返回输出
关于java - ClassNotFoundException:derby ClientDriver(Spring MVC + Hibernate JPA),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19785884/
我下载了Core Apache Derby database engine, which also includes the embedded JDBC driver (10.9.1.0)的jar 。
这个问题已经有答案了: What is the purpose of 'Class.forName("MY_JDBC_DRIVER")'? (4 个回答) 已关闭 7 年前。 有人可以向我解释一下这个
尝试连接到 derby 数据库时,出现以下错误: Jan 17, 2014 2:05:36 PM org.hibernate.validator.internal.util.Version INFO
我下载了Core Apache Derby database engine, which also includes the embedded JDBC driver (10.9.1.0)的jar .
我正在学习 Spring MVC,并尝试使用 hibernate 连接到数据库。MVC 部分有效,在一个单独的项目中,我还可以连接并使用 Derby 数据库。但是当我试图将两者放在一起时,我失败了。
这个问题在这里已经有了答案: Class [org.apache.derby.jdbc.ClientDriver] not found. When trying to connect to db (
我已经在 Netbeans 中建立了一个项目,创建了一个脚本,并使用 javadb 创建了一个新数据库。我可以通过 gui 连接到它 - 显示表格内容等,但是当我运行一个应用程序时: EntityM
我想使用 derby 在 netbeans 中操作我的数据库,但我收到此错误: java.lang.ClassNotFoundException: org.apach.derby.jdbc.Clien
我将 Kubuntu 13.10 与 Java 8 和 Netbeans 8.2.0 以及 MariaDB (MySQL) 一起用作我的数据库。我想学习 hibernate 。我创建了空的 Java
我已经通过 Maven Central (org.apache.derby) 下载了驱动程序。 Derby -10.15.1.3.jar derbyclient-10.15.1.3.jar derby
我已经通过 Maven Central (org.apache.derby) 下载了驱动程序。 derby-10.15.1.3.jar derbyclient-10.15.1.3.jar derbyn
我多次尝试在我的 Web 应用程序和 Derby 之间建立连接,但我在 eclipse 控制台中收到了这些错误消息: INFO: Server startup in 3772 ms ERROR: Ca
我是一名优秀的程序员,十分优秀!