当前位置:编程学习 > JAVA >>

java.lang.reflect.InvocationTargetException,SSH做批量删除的时候出现的错误

java.lang.reflect.InvocationTargetException
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
java.lang.reflect.Method.invoke(Method.java:597)
com.opensymphony.xwork2.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:441)
com.opensymphony.xwork2.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:280)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:243)
com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:165)
com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:87)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:252)
org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:68)
com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:87)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:122)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:195)
com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:87)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:195)
com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:87)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:179)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
org.apache.struts2.interceptor.MultiselectInterceptor.intercept(MultiselectInterceptor.java:75)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:94)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:235)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:89)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:130)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:126)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:138)
com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:87)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:165)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:179)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:237)
org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:488)
org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)


root cause 

--------------------编程问答-------------------- 这个貌似不是因为批量删除引起的。
可能是由于Action方法调用出的错,你把你的action代码贴出来看一下。 --------------------编程问答-------------------- 测试可以通过。。。
package com.lzh.action;

import com.lzh.service.ILinkService;
import com.opensymphony.xwork2.ActionSupport;


public class LinkDelAll extends ActionSupport{
    private ILinkService iLinkService;
    private Integer[] lid;
    
public ILinkService getiLinkService() {
return iLinkService;
}

public void setiLinkService(ILinkService iLinkService) {
this.iLinkService = iLinkService;
}



public Integer[] getLid() {
return lid;
}

public void setLid(Integer[] lid) {
this.lid = lid;
}

@Override
public String execute() throws Exception {
System.out.println("id="+lid);
for(int j:lid){
System.out.println("id="+j);
}
iLinkService.delAll(lid);
   return SUCCESS;
}
   
}
--------------------编程问答-------------------- 这是dao层的方法
public int delAll(final Integer[] lid) {
return (Integer) this.getHibernateTemplate().execute(
new HibernateCallback() {

public Object doInHibernate(Session session)
throws HibernateException, SQLException {
try {
String sql = "delete Link where lid in (:ids)";
Query query = getSession().createQuery(sql);
query.setParameterList("ids", lid);
// query.setParameter("ids", id);
query.executeUpdate();
} catch (Exception re) {
re.printStackTrace();
}
System.out.println("--------------");
return 1;
}

});
} --------------------编程问答-------------------- 这是我写的测试类
package com.lzh.service.impl;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;

import com.lzh.model.Link;
import com.lzh.service.ILinkService;
import com.lzh.service.IUserService;
import com.opensymphony.xwork2.interceptor.annotations.Before;

import junit.framework.TestCase;

public class TestLink extends TestCase {
 ILinkService   service;  
//IUserService userService;
    @Before  
    public void setUp() throws Exception  
    {  
        ApplicationContext context = new FileSystemXmlApplicationContext("E:\\Jean\\Workspaces\\MyEclipse 8.5\\struts_spring_hibernate01\\WebRoot\\WEB-INF\\applicationContext.xml");  
        service = (ILinkService) context.getBean("LinkService");  
        //userService=(IUserService)context.getBean("UserService");
    }  
    
//     public void testFindLinkById()  
//     {  
//         String yszmc = service.findById(1).getLname();  
//         System.out.println(yszmc);  
//         
//     }  
//     public void testSaveLink(){
//      Link link=new Link(222,"fasdf","dafd","dadsf");
//      service.save(link);
//     }
    public void testDelAll(){
     Integer[] i={7,8,9};
     System.out.println("i="+i);
     //service.delAll(i);
    }
}
--------------------编程问答-------------------- 既然dao层测试通过,那就说明action配置的有问题。
你好好分析下action配置哪里出问题了。 --------------------编程问答--------------------  in (:ids)";这里错了
补充:Java ,  Web 开发
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,