我正在学习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
如果有人有任何想法,为什么找不到课程,我很高兴知道! 我试图搜索谷歌和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";
}
@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";
}
答案 0 :(得分:3)
您需要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。会话工厂又使用数据源来获取它的连接。通过这种方式连接bean,Connection管理变得透明,您可以从应用程序中删除该代码。
在典型的n层应用程序中,数据访问实现的细节被封装在Repository / DAO层中,然后从Service层访问。服务层捕获业务逻辑并协调数据输入/检索。
您的Controller应该只关注在传递到服务层之前捕获/验证输入,并以客户端期望的格式返回输出(HTML,JSON,XML等)