2

我正在将 apache tomcat 与 eclipse keplee 一起使用。这是我的 jsp 文件,它运行一个 java 文件,该文件使用 sparql 从 tdb 查询。jsp文件:

<%@ page import="check.test4query"  %>
            <% test4query demo = new test4query();
            test4query dem = new test4query();
            String[] id =new String[20];
            String[] dat =new String[20];
            int i;
           demo.mai("SELECT ?x WHERE { ?y <TO:> 'hjcooljohny75@gmail.com' . ?y <SUB:> ?x} LIMIT 20 ");
           for(i=0;i<20;i++)
           {   id[i]=test4query.arr[i];
               id[i] = id[i].substring(0, Math.min(id[i].length(), 30));
           }
 for(i=0;i<20;i++)
            { //id[i]=test4query.arr[i];
                out.println("<tr>"+"&nbsp&nbsp&nbsp&nbsp"+id[i]+"<hr style='border-color:#E6E6E6;padding:0px;margin:0px'>"+"</tr>");
            }   
            %>

这是我的 test4query :

public static String[] arr=new String[20];
public  void  mai (String s) {
    //String s;
    //load the dataset 
    //String query1; 
    //query1="hjcooljohny75@gmail.com";
    //query1 = (String)(subjectentry.getText());
      //  s="SELECT ?x WHERE { ?y <TO:> '"+query1+"' . ?y <SUB:> ?x} LIMIT 20 ";
        System.out.println(s);
    String directory = "EMAILADDRESS" ;
    Dataset ds = TDBFactory.createDataset(directory) ;
    Model model = ds.getDefaultModel() ;
   ds.begin(ReadWrite.READ) ;
     QueryExecution qExec = QueryExecutionFactory.create(s, ds) ;
     int i=0;
     try{
     ResultSet rs = qExec.execSelect() ;
   String x=rs.toString();



    while (rs.hasNext()) {
        QuerySolution qs = rs.next();
        String rds;
        if(qs.get("x")!=null)
        rds = qs.get("x").toString();
        else rds="hi";
       // String em = (String)rs.getString();
        if(rds==null)
            break;
        //System.out.println(rds);
       arr[i] = rds;
       i++;
       //for (int i =0; i < arr.length; i++){


   }
   } finally
    {qExec.close() ;
    ds.commit();
    ds.end();
   }
    for( i=0;i<20;i++)
        System.out.println(arr[i]);
    //arr[0]="hi";


// return arr;
         //   try { 


          //      ResultSetFormatter.out(rs) ;
           // } finally { qExec.close() ; }

        // Another query - same view of the data.

}

问题是当我启动 tomcat 服务器时,它运行完美,显示结果,但之后如果我刷新页面,它会显示错误:

com.hp.hpl.jena.tdb.transaction.TDBTransactionException: Not in a transaction
    com.hp.hpl.jena.tdb.transaction.DatasetGraphTransaction.get(DatasetGraphTransaction.java:106)
    com.hp.hpl.jena.tdb.transaction.DatasetGraphTransaction.get(DatasetGraphTransaction.java:40)
    com.hp.hpl.jena.sparql.core.DatasetGraphTrackActive.getDefaultGraph(DatasetGraphTrackActive.java:91)
    com.hp.hpl.jena.sparql.core.DatasetImpl.getDefaultModel(DatasetImpl.java:103)
    check.test4query.mai(test4query.java:59)
    org.apache.jsp.grayscale.gmail_005flike_jsp._jspService(gmail_005flike_jsp.java:210)
    org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:725)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:432)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:403)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:347)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:725)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)

这一直发生但是当我重新启动服务器时它第一次显示正确的ans然后错误..我不知道是什么问题以及如何纠正它?

4

2 回答 2

3

这是错误的方式:

Model model = ds.getDefaultModel() ;
ds.begin(ReadWrite.READ) ;

请尝试:

ds.begin(ReadWrite.READ) ;
Model model = ds.getDefaultModel() ;
于 2014-06-13T17:15:40.203 回答
1

问题是您正在泄漏资源而不是自己清理

您通过ds.begin(ReadWrite.READ)调用启动事务,但从未通过ds.end()调用关闭事务,这就是后续调用失败并出现您看到的错误的原因。你也没有关闭你的QueryExecution

您应该使用 atry { } catch { } finally { }来确保您清理相关资源

于 2014-06-13T11:51:09.747 回答