JAVA 调用SAP接口定时读取数据存入本地数据库

package com.byd.emg.common;

import com.byd.emg.webservice.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Map;

import java.net.URL;
import javax.xml.namespace.QName;
import javax.xml.ws.BindingProvider;
import javax.xml.ws.Service;

@Component
public class TimerJobs {



//    @Autowired
//    private ZCNIFUNCLOCMD zcnifunclocmd;
//    private SAPERPPMCNFUNCLOCDATASIService saperppmcnfunclocdatasiService;

//    每分钟      采集wincc1数据到table1
    @Async
    @Scheduled(cron="0 0/1 * * * ?")

//    每天      采集wincc1数据到table1
//    @Async
//    @Scheduled(cron="0 0 0 * * ?" )

    public void TimeJobByDay() {
        try{
            SAPERPPMCNFUNCLOCDATASIService saperppmcnfunclocdatasiService =new SAPERPPMCNFUNCLOCDATASIService();
            SAPERPPMCNFUNCLOCDATASI saperppmcnfunclocdatasi= saperppmcnfunclocdatasiService.getHTTPPort();
            BindingProvider bindingProvider = (BindingProvider) saperppmcnfunclocdatasi;
            Map<String, Object> requestContext = bindingProvider.getRequestContext();
            requestContext.put("com.sun.xml.internal.ws.connection.timeout", 10 * 1000);//建立连接的超时时间为10秒
            requestContext.put("com.sun.xml.internal.ws.request.timeout", 15 * 1000);//指定请求的响应超时时间为15秒
            System.out.println("超时");
//            saperppmcnfunclocdatasiService.wait(1200000);

            ZCNIFUNCLOCMD zcnifunclocmd =new ZCNIFUNCLOCMD();
            ZCNIFUNCLOCBOM zcnifunclocbom = new ZCNIFUNCLOCBOM();
            ZCNIFUNCLOCTAPL zcnifuncloctapl = new ZCNIFUNCLOCTAPL();
            ZCNIFUNCLOCPLKO zcnifunclocplko =new ZCNIFUNCLOCPLKO();
            ZCNIFUNCLOCPLASPLPO zcnifunclocplasplpo = new ZCNIFUNCLOCPLASPLPO();
            ZCNIFUNCLOCPLMZ zcnifunclocplmz =new ZCNIFUNCLOCPLMZ();
            BAPIRET2 bapiret2 =new BAPIRET2();

            WERKSRANG werksrang = new WERKSRANG();
            werksrang.setSIGN("I"); //‘I’ - 表示包括, 'E' - 表示排除
            werksrang.setOPTION("EQ");//‘EQ’为等于,仅需赋Low;'BT'为从Low到High之间
            werksrang.setLOW("CN01"); //从工厂代码,如CN79表示宿迁
            werksrang.setHIGH(null);//到工厂代码,如CN01

            WCSTPLNR wcstplnr = new WCSTPLNR(); //功能位置号筛选
            //new WCS_TPLNR {                           //不输表示全部功能位置
            //    SIGN ="I",                            //‘I’ - 表示包括, 'E' - 表示排除
            //    OPTION ="EQ",                         //‘EQ’为等于,仅需赋Low;'BT'为从Low到High之间
            //    LOW ="CN79",                          //从功能位置号,如CN79表示宿迁
            //    HIGH =null                            //到功能位置号,如CN01
            //}

            //声明同步数据的开始时间和结束时间
            String I_UPDAT_END, I_UPDAT_START;
//            SimpleDateFormat format = new SimpleDateFormat("yyyyMMdd");
//            Calendar c = Calendar.getInstance();
//            c.setTime(new Date());
//            Date end = c.getTime();
//            I_ERDAT_END= format.format(end);//当前日期
//            c.add(Calendar.DATE, -1);
//            Date start = c.getTime();
//            I_ERDAT_START= format.format(start);//前一天
            I_UPDAT_START="20200101";
            I_UPDAT_END="20200415";

            System.out.println("参数完成");
            ZCNFUNCLOCINFORFC zcnfunclocinforfc=new ZCNFUNCLOCINFORFC();
            zcnfunclocinforfc.setIBOM("X");
            zcnfunclocinforfc.setIMD("X");
            zcnfunclocinforfc.setITASK("X");
            zcnfunclocinforfc.setIUPDATSTART(I_UPDAT_START);
            zcnfunclocinforfc.setIUPDATEND(I_UPDAT_END);

            // 设置访问接口服务器的用户名和密码
            BindingProvider bp = (BindingProvider) saperppmcnfunclocdatasi;
            Map<String, Object> context = bp.getRequestContext();
            context.put(BindingProvider.USERNAME_PROPERTY, "MDBCPIC");
            context.put(BindingProvider.PASSWORD_PROPERTY, "Mdbcpi2017!");

            saperppmcnfunclocdatasi.saperpPMCNFUNCLOCDATASI(zcnfunclocinforfc);
            System.out.println("通过连接");
        }
        catch (Exception e){
            System.out.println(e);
        }

        System.out.println("每分钟执行一次");
    }




    //根据传入的年月减去一天
    public String subtractDay(String date) {
        SimpleDateFormat df= new SimpleDateFormat("yyyy-MM-dd");
        String returnDate=date;
        try {
            Calendar rightNow = Calendar.getInstance();
            Date begin_d1=df.parse(date);
            rightNow.setTime(begin_d1);
            rightNow.add(Calendar.DAY_OF_MONTH,-1);
            returnDate=df.format(rightNow.getTime());
        } catch (ParseException e) {
            e.printStackTrace();
        }
        return returnDate;
    }

    //判断当前日期是否是本月的最后一天
    public static boolean isLastDayOfMonth(Date date) {
        Calendar calendar = Calendar.getInstance();
        calendar.setTime(date);
        calendar.set(Calendar.DATE, (calendar.get(Calendar.DATE) + 1));
        if (calendar.get(Calendar.DAY_OF_MONTH) == 1) {
            return true;
        }
        return false;
    }




}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个用Java调用API接口并将数据存入数据库的示例代码: ``` import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import java.net.HttpURLConnection; import java.net.URL; import java.io.BufferedReader; import java.io.InputStreamReader; import org.json.JSONArray; import org.json.JSONObject; public class APICall { public static void main(String[] args) { Connection conn = null; try { // Connect to the database String url = "jdbc:mysql://localhost/mydatabase"; String user = "root"; String password = "password"; conn = DriverManager.getConnection(url, user, password); // Call the API and get the data URL apiUrl = new URL("api_endpoint_url&params"); HttpURLConnection connection = (HttpURLConnection) apiUrl.openConnection(); connection.setRequestMethod("GET"); BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream())); StringBuilder response = new StringBuilder(); String line; while ((line = reader.readLine()) != null) { response.append(line); } reader.close(); // Parse the JSON response and insert into the database JSONArray data = new JSONArray(response.toString()); for (int i = 0; i < data.length(); i++) { JSONObject object = data.getJSONObject(i); PreparedStatement statement = conn.prepareStatement("INSERT INTO mytable (column1, column2, column3) VALUES (?, ?, ?)"); statement.setString(1, object.getString("field1")); statement.setInt(2, object.getInt("field2")); statement.setDouble(3, object.getDouble("field3")); statement.executeUpdate(); } // Close the database connection conn.close(); } catch (SQLException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { try { if (conn != null) { conn.close(); } } catch (SQLException ex) { ex.printStackTrace(); } } } } ``` 这段代码可以连接到MySQL数据库,并从一个API接口中获取数据,然后将数据存入数据库。在实际使用时,需要将`api_endpoint_url&params`部分替换成实际的API接口地址和参数。同时也需要将数据库连接信息和SQL语句中的表名和列名替换成实际的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值