Я получаю сообщение об ошибке при обновлении отчета в BO. Что мне нужно сделать, это обновить отчет в BO и найти время, которое потребовалось для этого. Как только я нахожу все это, мне нужно вставить эти данные в таблицу MySQL.
Пока я это делаю, я получаю следующую ошибку.
Исключение в потоке "main" com.businessobjects.rebean.wi.ServerException: произошла ошибка базы данных. Текст ошибки базы данных: (CS) «DBDriver не удалось загрузить: C: \ Program Files \ Business Objects \ BusinessObjects Enterprise 12.0 \ win32_x86 \ dataAccess \ connectionServer \ dbd_oci.dll (указанный модуль не найден.
) ". (МДП 10901)
Как это вызвано и как я могу решить?
Вот код BO:
import java.util.Iterator;
import java.sql.*;
import com.businessobjects.rebean.wi.DocumentInstance;
import com.businessobjects.rebean.wi.ReportEngine;
import com.businessobjects.rebean.wi.ReportEngines;
import com.crystaldecisions.sdk.exception.SDKException;
import com.crystaldecisions.sdk.framework.CrystalEnterprise;
import com.crystaldecisions.sdk.framework.IEnterpriseSession;
import com.crystaldecisions.sdk.framework.ISessionMgr;
import com.crystaldecisions.sdk.occa.infostore.IInfoObject;
import com.crystaldecisions.sdk.occa.infostore.IInfoObjects;
import com.crystaldecisions.sdk.occa.infostore.IInfoStore;
public class RefreshWebi {
/**
* @param args
* @throws ClassNotFoundException
* @throws SQLException
*/
public static void main(String[] args) throws ClassNotFoundException, SQLException {
// TODO Auto-generated method stub
String cms="172.16.56.114";
String username="administrator";
String password="";
String auth="secEnterprise";
String driver="com.mysql.jdbc.Driver";
Connection conn;
IEnterpriseSession enterpriseSession;
System.out.println("success");
Long currentTime;
try {
ISessionMgr sessionMgr=CrystalEnterprise.getSessionMgr();
enterpriseSession=sessionMgr.logon(username, password,cms, auth);
IInfoStore iStore=(IInfoStore)enterpriseSession.getService("InfoStore");
//bologger.entering("BOUtilities", "refreshWebIReport");
IInfoObjects reportObjects = iStore.query("select top 1 * from ci_infoobjects where si_kind='webi'");
ReportEngines reportEngines = (ReportEngines) enterpriseSession.getService("ReportEngines");
ReportEngine reportEngine = reportEngines.getService(ReportEngines.ReportEngineType.WI_REPORT_ENGINE);
Iterator it = reportObjects.iterator();
while (it.hasNext()) {
IInfoObject reportObject = (IInfoObject) it.next();
DocumentInstance documentInstance = reportEngine
.openDocument(reportObject.getID());
currentTime = System.currentTimeMillis();
documentInstance.refresh();
System.out.println("Time taken to refresh "
+ (System.currentTimeMillis() - currentTime) / 1000);
documentInstance.closeDocument();
int documentID = reportObject.getID();
String documentName=reportObject.getTitle();
long refreshtime=currentTime.intValue();
long refreshDuration=(System.currentTimeMillis() - currentTime) / 1000;
int refreshtimes=(int)refreshtime;
int refdur=(int)refreshDuration;
System.out.println("Document id :"+documentID);
System.out.println("Document name :"+documentName);
System.out.println("Refreshtime :"+refreshtimes);
System.out.println("Refresh duration :"+refdur);
Class.forName(driver);
conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password");
Statement st=conn.createStatement();
st.executeUpdate("insert into refreshtimings (documentid,documentname,refreshtime,refreshduration)values('"+documentID+"','"+documentName+"','"+refreshtimes+"','"+refdur+"')");
conn.close();
}
reportEngine.close();
reportEngines.close();
} catch (SDKException e) {
e.printStackTrace();
}
}