2015-01-03 111 views
1

我正在浏览Apache Camel并希望将数据插入数据库。 我的数据库是SqlServer。 Apache的骆驼版本是2.14.1Apache Camel JDBC插入

这是我试过至今,

import javax.sql.DataSource; 

import org.apache.camel.CamelContext; 
import org.apache.camel.builder.RouteBuilder; 
import org.apache.camel.impl.DefaultCamelContext; 
import org.apache.camel.impl.SimpleRegistry; 
import org.apache.commons.dbcp.BasicDataSource; 

public class file2DB { 

    public static void main(String[] args) throws Exception { 
     final String url = "jdbc:sqlserver://localhost:1433;databaseName=TestDB"; 

     DataSource datasource = setupDataSource(url); 
     SimpleRegistry simpleregistry = new SimpleRegistry(); 
     simpleregistry.put("DataSource", datasource); 
     CamelContext context = new DefaultCamelContext(simpleregistry); 
     context.addRoutes(new file2DB().new MyRouteBuilder()); 

     context.start(); 
     Thread.sleep(20000); 
     context.stop(); 
    } 

    class MyRouteBuilder extends RouteBuilder { 
     @Override 
     public void configure() throws Exception { 
      try { 

       from("direct:myTable") 
       .setBody(constant("INSERT INTO employee1(empId,payrollId) VALUES('1234','4567')")) 
       .to("jdbc:DataSource"); 

      } catch (Exception e) { 
       e.printStackTrace(); 
      } 

     } 
    } 
    private static DataSource setupDataSource(String url){ 
     BasicDataSource basicDataSource = new BasicDataSource(); 
     basicDataSource.setDriverClassName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); 
     basicDataSource.setUsername("sa"); 
     basicDataSource.setPassword("*****"); 
     basicDataSource.setUrl(url); 
     return basicDataSource; 
    } 

} 

我使用下面的代码检查数据源连接和我得到的结果,所以没有问题,与它的连接看来。

 Connection con=null; 
     try { 
      con = basicDataSource.getConnection(); 
      Statement st = con.createStatement(); 
      ResultSet rs = st.executeQuery("select * from employee1"); 

      while (rs.next()) { 
       System.out.println(rs.getString(2)); 
      } 

     } catch (SQLException e) { 
      e.printStackTrace(); 
     } 

我没有收到任何错误,数据也没有插入表中。 我也试过“选择”查询也是不起作用。

我试过记录器,它给我日志中的许多错误没有类defn发现微博等,我没有使用,我认为我的错误是不相关的。

任何帮助。

+0

应该有一些错误/服务器终端,在例外情况某些异常情况发生时, - 当某些东西没有插入或从关联的数据库中检索时。当您试图插入数据库或从数据库中检索时,您是否在服务器日志上获取任何内容 - 堆栈跟踪? – Tiny

+0

如果服务器端出现错误,那么我认为我试过测试数据源的基本选择查询也应该失败吧? – Jayesh

+0

我尝试了MySQL,同样的问题仍然存在。我似乎在骆驼api中缺少一些东西。 – Jayesh

回答