/* package whatever; // don't place package name! */
import javafx.concurrent.Task ;
import javafx.event.ActionEvent ;
import java.sql.Connection ;
import java.sql.DriverManager ;
import java.sql.SQLException ;
import java.sql.Statement ;
import java.sql.ResultSet ;
import static com.Ostermiller .util .StringHelper .escapeSQL ;
import static java.
lang .
Math .
abs ;
public class ResultsReader extends Task< Integer>
{
// User settings - adjust for best perfromance
private static int NumberOfResultsThreads = 10 ;
private static int NumberOfResultsContactsToProcessPerThread = 1000 ;
private static int NumberOfRecordsToInsertAtATime = 100 ;
private static String TypeMask
= "1,2,3,5" ; private static String RemoteUser
= "myusername" ; private static String RemotePass
= "mypassword" ; private static String MainUser
= "MainUser" ; private static String MainPass
= "MainPassword" ;
// Alllows different systems to use the same RXDialers
private static int ESID = - 15 ;
private int CurrModValue;
/*private String CurrRemoteIPAddress1 = "aa.aa.a.aaa";
private String CurrRemoteIPAddress2 = "bb.bb.b.bbb";
private String CurrRemoteIPAddress3 = "cc.cc.c.ccc";
private String CurrRemoteIPAddress4 = "dd.dd.d.ddd";
private String CurrRemoteIPAddress5 = "ee.ee.e.eee";
private String CurrRemoteIPAddress6 = "ff.ff.f.fff";
private String CurrRemoteIPAddress7 = "gg.gg.g.ggg";*/
// Task local reference to the controller class to call back to when complete
private EBMExtractorFXMLController QRVC;
public void setQDVC( EBMExtractorFXMLController QRVC)
{
this .QRVC = QRVC;
}
public EBMExtractorFXMLController getQDVC( )
{
return QRVC;
}
public ResultsReader( int CurrModValue)
{
this .CurrModValue = CurrModValue;
}
public void act_StartProcessing( )
{
}
public void act_StopProcessing( )
{
this .cancel ( ) ;
}
{
int iterations = 0 ;
int i = 0 ;
boolean done = false ;
while ( ! done) {
try
{
//Connection connMain = DriverManager.getConnection("jdbc:mysql://" + CurrRemoteIPAddress + ":3306/test",RemoteUser,RemotePass);
RemoteIPAddress[ 0 ] = "aa.aa.a.aaa" ;
RemoteIPAddress[ 1 ] = "bb.bb.b.bbb" ;
RemoteIPAddress[ 2 ] = "cc.cc.c.ccc" ;
RemoteIPAddress[ 3 ] = "dd.dd.d.ddd" ;
RemoteIPAddress[ 4 ] = "ee.ee.e.eee" ;
RemoteIPAddress[ 5 ] = "ff.ff.f.fff" ;
RemoteIPAddress[ 6 ] = "gg.gg.g.ggg" ;
MainConnection
[ 0 ] = DriverManager .
getConnection ( "jdbc:mysql://" + RemoteIPAddress
[ 0 ] + ":3306/test" ,RemoteUser,RemotePass
) ; MainConnection
[ 1 ] = DriverManager .
getConnection ( "jdbc:mysql://" + RemoteIPAddress
[ 1 ] + ":3306/test" ,RemoteUser,RemotePass
) ; MainConnection
[ 2 ] = DriverManager .
getConnection ( "jdbc:mysql://" + RemoteIPAddress
[ 2 ] + ":3306/test" ,RemoteUser,RemotePass
) ; MainConnection
[ 3 ] = DriverManager .
getConnection ( "jdbc:mysql://" + RemoteIPAddress
[ 3 ] + ":3306/test" ,RemoteUser,RemotePass
) ; MainConnection
[ 4 ] = DriverManager .
getConnection ( "jdbc:mysql://" + RemoteIPAddress
[ 4 ] + ":3306/test" ,RemoteUser,RemotePass
) ; MainConnection
[ 5 ] = DriverManager .
getConnection ( "jdbc:mysql://" + RemoteIPAddress
[ 5 ] + ":3306/test" ,RemoteUser,RemotePass
) ; MainConnection
[ 6 ] = DriverManager .
getConnection ( "jdbc:mysql://" + RemoteIPAddress
[ 6 ] + ":3306/test" ,RemoteUser,RemotePass
) ;
String QueryString
= " SELECT " + " RXCallDetailId_int, "
+ " DTSID_int, "
+ " CallDetailsStatusId_ti, "
+ " BatchId_bi, "
+ " PhoneId_int, "
+ " TotalObjectTime_int, "
+ " TotalCallTimeLiveTransfer_int, "
+ " TotalCallTime_int, "
+ " TotalAnswerTime_int, "
+ " UserSpecifiedLineNumber_si, "
+ " NumberOfHoursToRescheduleRedial_si, "
+ " TransferStatusId_ti, "
+ " IsHangUpDetected_ti, "
+ " IsOptOut_ti, "
+ " IsMaxRedialsReached_ti, "
+ " IsRescheduled_ti, "
+ " CallResult_int, "
+ " SixSecondBilling_int, "
+ " SystemBilling_int, "
+ " RXCDLStartTime_dt, "
+ " CallStartTime_dt, "
+ " CallEndTime_dt, "
+ " CallStartTimeLiveTransfer_dt, "
+ " CallEndTimeLiveTransfer_dt, "
+ " CallResultTS_dt, "
+ " PlayFileStartTime_dt, "
+ " PlayFileEndTime_dt, "
+ " HangUpDetectedTS_dt, "
+ " Created_dt, "
+ " DialerName_vch, "
+ " CurrTS_vch, "
+ " CurrVoice_vch, "
+ " CurrTSLiveTransfer_vch, "
+ " CurrVoiceLiveTransfer_vch, "
+ " CurrCDP_vch, "
+ " CurrCDPLiveTransfer_vch, "
+ " DialString_vch, "
+ " RedialNumber_int, "
+ " TimeZone_ti, "
+ " MessageDelivered_si, "
+ " SingleResponseSurvey_si, "
+ " ReplayTotalCallTime_int, "
+ " XMLResultStr_vch, "
+ " TotalConnectTime_int, "
+ " IsOptIn_ti, "
+ " FileSeqNumber_int, "
+ " UserSpecifiedData_vch, "
+ " XMLControlString_vch, "
+ " DTS_UUID_vch, "
+ " MainMessageLengthSeconds_int "
+ " FROM "
+ " calldetail.rxcalldetails_test "
+ " WHERE "
+ " CallDetailsStatusId_ti = " + ESID
+ " AND RXCallDetailId_int MOD " + NumberOfResultsThreads + " = " + CurrModValue
+ " ORDER BY RXCallDetailId_int ASC "
+ " LIMIT " + NumberOfResultsContactsToProcessPerThread ;
//SelectResultsStmt = connMain.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
SelectResultsStmt
= MainConnection
[ i
] .
createStatement ( ResultSet .
TYPE_SCROLL_SENSITIVE ,
ResultSet .
CONCUR_UPDATABLE ) ; SelectResultsRS = SelectResultsStmt.executeQuery ( QueryString) ;
int CurrentBillingAmount = 0 ;
int CurrentRowCount = 0 ;
String QueryStringInsertFromRemote
= "" ;
// Now do something with the ResultSet ....
while ( SelectResultsRS.
next ( ) && ! Thread .
interrupted ( ) ) { // While SelectResultsRS
CurrentRowCount++;
// Allow thread to be canceled
if ( isCancelled( ) )
{
// Do any additional clean up here - maybe update main DB of non-processed?
updateMessage( "Cancelled" ) ;
break ;
}
// When a progress is bound (.bind()) to this task - this will update the progress meter
updateProgress( SelectResultsRS.getRow ( ) , NumberOfResultsContactsToProcessPerThread) ;
updateMessage( "Thread " + CurrModValue + " " + SelectResultsRS.getInt ( "DTSId_int" ) ) ;
// Get Billing amount - need billing method in JAVA
CurrentBillingAmount = 0 ;
// System.out.println(SelectResultsRS.getInt("DTSId_int"));
QueryStringInsertFromRemote = " INSERT INTO SimpleXResults.ContactResults_test "
+ " ( "
+ " MasterRXCallDetailId_int, "
+ " RXCallDetailId_int, "
+ " DTSID_int, "
+ " BatchId_bi, "
+ " PhoneId_int, "
+ " TotalObjectTime_int, "
+ " TotalCallTimeLiveTransfer_int, "
+ " TotalCallTime_int, "
+ " TotalConnectTime_int, "
+ " ReplayTotalCallTime_int, "
+ " TotalAnswerTime_int, "
+ " UserSpecifiedLineNumber_si, "
+ " NumberOfHoursToRescheduleRedial_si, "
+ " TransferStatusId_ti, "
+ " IsHangUpDetected_ti, "
+ " IsOptOut_ti, "
+ " IsMaxRedialsReached_ti, "
+ " IsRescheduled_ti, "
+ " CallResult_int, "
+ " SixSecondBilling_int, "
+ " SystemBilling_int, "
+ " RXCDLStartTime_dt, "
+ " CallStartTime_dt, "
+ " CallEndTime_dt, "
+ " CallStartTimeLiveTransfer_dt, "
+ " CallEndTimeLiveTransfer_dt, "
+ " CallResultTS_dt, "
+ " PlayFileStartTime_dt, "
+ " PlayFileEndTime_dt, "
+ " HangUpDetectedTS_dt, "
+ " Created_dt, "
+ " DialerName_vch, "
+ " DialerIP_vch, "
+ " CurrTS_vch, "
+ " CurrVoice_vch, "
+ " CurrTSLiveTransfer_vch, "
+ " CurrVoiceLiveTransfer_vch, "
+ " CurrCDP_vch, "
+ " CurrCDPLiveTransfer_vch, "
+ " ContactString_vch, "
+ " RedialNumber_int, "
+ " TimeZone_ti, "
+ " MessageDelivered_si, "
+ " SingleResponseSurvey_si, "
+ " XMLResultStr_vch, "
+ " IsOptIn_ti, "
+ " ActualCost_int, "
+ " DTS_UUID_vch, "
+ " XMLControlString_vch, "
+ " UserSpecifiedData_vch, "
+ " FileSeqNumber_int, "
+ " MainMessageLengthSeconds_int "
+ " ) "
+ " VALUES "
+ " ( "
+ " NULL, "
+ " " + SelectResultsRS.getInt ( "RXCallDetailId_int" ) + ", " // #ExtractFromDialer.RXCallDetailId_int#,
+ " " + SelectResultsRS.getInt ( "DTSID_int" ) + ", " //#ExtractFromDialer.DTSID_int#,
+ " " + SelectResultsRS.getInt ( "BatchId_bi" ) + ", " //#ExtractFromDialer.BatchId_bi#,
+ " " + SelectResultsRS.getInt ( "PhoneId_int" ) + ", " //#ExtractFromDialer.PhoneId_int#,
+ " " + SelectResultsRS.getInt ( "TotalObjectTime_int" ) + ", " //#ExtractFromDialer.TotalObjectTime_int#,
+ " " + SelectResultsRS.getInt ( "TotalCallTimeLiveTransfer_int" ) + ", " //#ExtractFromDialer.TotalCallTimeLiveTransfer_int#,
+ " " + SelectResultsRS.getInt ( "TotalCallTime_int" ) + ", " //#ExtractFromDialer.TotalCallTime_int#,
+ " " + SelectResultsRS.getInt ( "TotalConnectTime_int" ) + ", " //#ExtractFromDialer.TotalConnectTime_int#,
+ " " + SelectResultsRS.getInt ( "ReplayTotalCallTime_int" ) + ", " //#ExtractFromDialer.ReplayTotalCallTime_int#,
+ " " + SelectResultsRS.getInt ( "TotalAnswerTime_int" ) + ", " //#ExtractFromDialer.TotalAnswerTime_int#,
+ " " + SelectResultsRS.getInt ( "UserSpecifiedLineNumber_si" ) + ", " //#ExtractFromDialer.UserSpecifiedLineNumber_si#,
+ " " + SelectResultsRS.getInt ( "NumberOfHoursToRescheduleRedial_si" ) + ", " //#ExtractFromDialer.NumberOfHoursToRescheduleRedial_si#,
+ " " + SelectResultsRS.getInt ( "TransferStatusId_ti" ) + ", " //#ExtractFromDialer.TransferStatusId_ti#,
+ " " + SelectResultsRS.getInt ( "IsHangUpDetected_ti" ) + ", " //#ExtractFromDialer.IsHangUpDetected_ti#,
+ " " + SelectResultsRS.getInt ( "IsOptOut_ti" ) + ", " //#ExtractFromDialer.IsOptOut_ti#,
+ " " + SelectResultsRS.getInt ( "IsMaxRedialsReached_ti" ) + ", " //#ExtractFromDialer.IsMaxRedialsReached_ti#,
+ " " + SelectResultsRS.getInt ( "IsRescheduled_ti" ) + ", " //#ExtractFromDialer.IsRescheduled_ti#,
+ " " + SelectResultsRS.getInt ( "CallResult_int" ) + ", " //#ExtractFromDialer.CallResult_int#,
+ " " + SelectResultsRS.getInt ( "SixSecondBilling_int" ) + ", " //#ExtractFromDialer.SixSecondBilling_int#,
+ " " + SelectResultsRS.getInt ( "SystemBilling_int" ) + ", " //#ExtractFromDialer.SystemBilling_int#,
+ " '" + SelectResultsRS.getString ( "RXCDLStartTime_dt" ) + "', " //'#ExtractFromDialer.RXCDLStartTime_dt#',
+ " '" + SelectResultsRS.getString ( "CallStartTime_dt" ) + "', " //'#ExtractFromDialer.CallStartTime_dt#',
+ " '" + SelectResultsRS.getString ( "CallEndTime_dt" ) + "', " //'#ExtractFromDialer.CallEndTime_dt#',
+ " '" + SelectResultsRS.getString ( "CallStartTimeLiveTransfer_dt" ) + "', " //'#ExtractFromDialer.CallStartTimeLiveTransfer_dt#',
+ " '" + SelectResultsRS.getString ( "CallEndTimeLiveTransfer_dt" ) + "', " //'#ExtractFromDialer.CallEndTimeLiveTransfer_dt#',
+ " '" + SelectResultsRS.getString ( "CallResultTS_dt" ) + "', " //'#ExtractFromDialer.CallResultTS_dt#',
+ " '" + SelectResultsRS.getString ( "PlayFileStartTime_dt" ) + "', " //'#ExtractFromDialer.PlayFileStartTime_dt#',
+ " '" + SelectResultsRS.getString ( "PlayFileEndTime_dt" ) + "', " //'#ExtractFromDialer.PlayFileEndTime_dt#',
+ " '" + SelectResultsRS.getString ( "HangUpDetectedTS_dt" ) + "', " //'#ExtractFromDialer.HangUpDetectedTS_dt#',
+ " '" + SelectResultsRS.getString ( "Created_dt" ) + "', " //'#ExtractFromDialer.Created_dt#',
+ " '" + SelectResultsRS.getString ( "DialerName_vch" ) + "', " //'#ExtractFromDialer.DialerName_vch#',
+ " '" + RemoteIPAddress[ i] + "', " //'#inpDialerIPAddr#',
+ " '" + SelectResultsRS.getString ( "CurrTS_vch" ) + "', " //'#ExtractFromDialer.CurrTS_vch#',
+ " '" + SelectResultsRS.getString ( "CurrVoice_vch" ) + "', " //'#ExtractFromDialer.CurrVoice_vch#',
+ " '" + SelectResultsRS.getString ( "CurrTSLiveTransfer_vch" ) + "', " //'#ExtractFromDialer.CurrTSLiveTransfer_vch#',
+ " '" + SelectResultsRS.getString ( "CurrVoiceLiveTransfer_vch" ) + "', " //'#ExtractFromDialer.CurrVoiceLiveTransfer_vch#',
+ " '" + SelectResultsRS.getString ( "CurrCDP_vch" ) + "', " //'#ExtractFromDialer.CurrCDP_vch#',
+ " '" + SelectResultsRS.getString ( "CurrCDPLiveTransfer_vch" ) + "', " //'#ExtractFromDialer.CurrCDPLiveTransfer_vch#',
+ " '" + escapeSQL( SelectResultsRS.getString ( "DialString_vch" ) ) + "', " //'#ExtractFromDialer.DialString_vch#',
+ " " + SelectResultsRS.getInt ( "RedialNumber_int" ) + ", " //#ExtractFromDialer.RedialNumber_int#,
+ " " + SelectResultsRS.getInt ( "TimeZone_ti" ) + ", " //#ExtractFromDialer.TimeZone_ti#,
+ " " + SelectResultsRS.getInt ( "MessageDelivered_si" ) + ", " //#ExtractFromDialer.MessageDelivered_si#,
+ " " + SelectResultsRS.getInt ( "SingleResponseSurvey_si" ) + ", " //#ExtractFromDialer.SingleResponseSurvey_si#,
+ " '" + escapeSQL( SelectResultsRS.getString ( "XMLResultStr_vch" ) ) + "', " //<CFQUERYPARAM CFSQLTYPE="CF_SQL_VARCHAR" VALUE="#ExtractFromDialer.XMLResultStr_vch#">,
+ " " + SelectResultsRS.getInt ( "IsOptIn_ti" ) + ", " //#ExtractFromDialer.IsOptIn_ti#,
+ " " + CurrentBillingAmount + ", " //#CurrentBillingAmount#,
+ " '" + SelectResultsRS.getString ( "DTS_UUID_vch" ) + "', " //'#ExtractFromDialer.DTS_UUID_vch#',
+ " '" + escapeSQL( SelectResultsRS.getString ( "XMLControlString_vch" ) ) + "', " // <CFQUERYPARAM CFSQLTYPE="CF_SQL_VARCHAR" VALUE="#ExtractFromDialer.XMLControlString_vch#">,
+ " '" + escapeSQL( SelectResultsRS.getString ( "UserSpecifiedData_vch" ) ) + "', " // <CFQUERYPARAM CFSQLTYPE="CF_SQL_VARCHAR" VALUE="#ExtractFromDialer.UserSpecifiedData_vch#">,
+ " " + SelectResultsRS.getInt ( "FileSeqNumber_int" ) + ", " // <cfif ExtractFromDialer.FileSeqNumber_int NEQ "">#ExtractFromDialer.FileSeqNumber_int#<cfelse>NULL</cfif>,
+ " " + SelectResultsRS.getInt ( "MainMessageLengthSeconds_int" ) + " " //#ExtractFromDialer.MainMessageLengthSeconds_int#
+ " ) " ;
SelectResultsRS.updateInt ( "CallDetailsStatusId_ti" , abs( ESID) ) ;
InsertRemoteResultsStmt = connRemote.createStatement ( ) ;
InsertRemoteResultsStmt.executeUpdate ( QueryStringInsertFromRemote) ;
// reset string to empty
QueryStringInsertFromRemote = "" ;
SelectResultsRS.updateRow ( ) ;
} // While SelectResultsRS
// Execute Insert on any remainging records
if ( QueryStringInsertFromRemote.length ( ) > 0 )
{
InsertRemoteResultsStmt = connRemote.createStatement ( ) ;
InsertRemoteResultsStmt.executeUpdate ( QueryStringInsertFromRemote) ;
QueryStringInsertFromRemote = "" ;
SelectResultsRS.updateRow ( ) ;
}
if ( CurrentRowCount == 0 )
{
// Write to log that there was nothing to process
System .
out .
println ( "No results found this loop" ) ;
// Only sleep while listening for cancel task/thread calls
try
{
}
{
if ( isCancelled( ) )
{
System .
out .
println ( "QRC Cancelled" ) ; // break;
}
}
}
done = true ;
}
{
// handle any errors
System .
out .
println ( "SQLException: " + ex.
getMessage ( ) ) ; System .
out .
println ( "SQLState: " + ex.
getSQLState ( ) ) ; System .
out .
println ( "VendorError: " + ex.
getErrorCode ( ) ) ; i++;
}
finally
{
// it is a good idea to release
// resources in a finally{} block
// in reverse-order of their creation
// if they are no-longer needed
if ( SelectResultsRS != null )
{
try
{
SelectResultsRS.close ( ) ;
}
{
} // ignore
SelectResultsRS = null ;
}
if ( SelectResultsStmt != null )
{
try
{
SelectResultsStmt.close ( ) ;
}
{
} // ignore
SelectResultsStmt = null ;
}
if ( UpdateResultsStmt != null )
{
try
{
UpdateResultsStmt.close ( ) ;
}
{
} // ignore
UpdateResultsStmt = null ;
}
if ( InsertRemoteResultsStmt != null )
{
try
{
InsertRemoteResultsStmt.close ( ) ;
}
{
} // ignore
InsertRemoteResultsStmt = null ;
}
}
QRVC.ResultsReaderCallBackonComplete ( CurrModValue) ;
return iterations;
}
}
}
/* package whatever; // don't place package name! */


import javafx.concurrent.Task;
import javafx.event.ActionEvent;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSet;



import static com.Ostermiller.util.StringHelper.escapeSQL;
import static java.lang.Math.abs;

       
        
 public class ResultsReader extends Task<Integer> 
 {
        // User settings - adjust for best perfromance 
        private static int NumberOfResultsThreads = 10;
        private static int NumberOfResultsContactsToProcessPerThread = 1000;
        private static int NumberOfRecordsToInsertAtATime = 100;
        private static String TypeMask = "1,2,3,5";
        private static String RemoteUser = "myusername";
        private static String RemotePass = "mypassword";
        private static String MainUser = "MainUser";
        private static String MainPass = "MainPassword";
        
        // Alllows different systems to use the same RXDialers
        private static int ESID = -15;
        
        
        private int CurrModValue;
        private static String IP[];
        /*private String CurrRemoteIPAddress1 = "aa.aa.a.aaa";
        private String CurrRemoteIPAddress2 = "bb.bb.b.bbb";
        private String CurrRemoteIPAddress3 = "cc.cc.c.ccc";
        private String CurrRemoteIPAddress4 = "dd.dd.d.ddd";
        private String CurrRemoteIPAddress5 = "ee.ee.e.eee";
        private String CurrRemoteIPAddress6 = "ff.ff.f.fff";
        private String CurrRemoteIPAddress7 = "gg.gg.g.ggg";*/
        
        // Task local reference to the controller class to call back to when complete       
        private EBMExtractorFXMLController QRVC;
        
        public void setQDVC(EBMExtractorFXMLController QRVC)
        {
           this.QRVC = QRVC;
        }

        public EBMExtractorFXMLController getQDVC()
        {
               return QRVC;
        }
  
    
    
        public ResultsReader(int CurrModValue) 
        {
            this.CurrModValue = CurrModValue;
        }
         
        public void act_StartProcessing() 
        {
            new Thread(this).start();

        }

        public void act_StopProcessing() 
        {
            this.cancel();                  
        }
      
               

         @Override protected Integer call() throws Exception 
         {
            int iterations = 0;
                       
            int i = 0;
            boolean done = false; 
           
            Statement SelectResultsStmt = null;
            Statement UpdateResultsStmt = null;
            Statement InsertRemoteResultsStmt = null;
            ResultSet SelectResultsRS = null;

            while(!done) {
            try 
            {
                //Connection connMain = DriverManager.getConnection("jdbc:mysql://" + CurrRemoteIPAddress + ":3306/test",RemoteUser,RemotePass);
                
                Connection[] MainConnection = new Connection[7];
                
                String[] RemoteIPAddress = new String[7];
                
                RemoteIPAddress[0] = "aa.aa.a.aaa";
                RemoteIPAddress[1] = "bb.bb.b.bbb";
                RemoteIPAddress[2] = "cc.cc.c.ccc";
                RemoteIPAddress[3] = "dd.dd.d.ddd";
                RemoteIPAddress[4] = "ee.ee.e.eee";
                RemoteIPAddress[5] = "ff.ff.f.fff";
                RemoteIPAddress[6] = "gg.gg.g.ggg";
                
                MainConnection[0]  = DriverManager.getConnection("jdbc:mysql://" + RemoteIPAddress[0] + ":3306/test",RemoteUser,RemotePass);
                MainConnection[1]  = DriverManager.getConnection("jdbc:mysql://" + RemoteIPAddress[1] + ":3306/test",RemoteUser,RemotePass);
                MainConnection[2]  = DriverManager.getConnection("jdbc:mysql://" + RemoteIPAddress[2] + ":3306/test",RemoteUser,RemotePass);
                MainConnection[3]  = DriverManager.getConnection("jdbc:mysql://" + RemoteIPAddress[3] + ":3306/test",RemoteUser,RemotePass);
                MainConnection[4]  = DriverManager.getConnection("jdbc:mysql://" + RemoteIPAddress[4] + ":3306/test",RemoteUser,RemotePass);
                MainConnection[5]  = DriverManager.getConnection("jdbc:mysql://" + RemoteIPAddress[5] + ":3306/test",RemoteUser,RemotePass);
                MainConnection[6]  = DriverManager.getConnection("jdbc:mysql://" + RemoteIPAddress[6] + ":3306/test",RemoteUser,RemotePass);
                
                Connection connRemote = DriverManager.getConnection("jdbc:mysql://xx.xx.x.xxx:3306/test",MainUser,MainPass); 
                 

                String QueryString =      " SELECT "  
                                        + "     RXCallDetailId_int, "
                                        + "     DTSID_int, "
                                        + "     CallDetailsStatusId_ti, "
                                        + "     BatchId_bi, "
                                        + "     PhoneId_int, "
                                        + "     TotalObjectTime_int, "
                                        + "     TotalCallTimeLiveTransfer_int, "
                                        + "     TotalCallTime_int, "
                                        + "     TotalAnswerTime_int, "
                                        + "     UserSpecifiedLineNumber_si, "
                                        + "     NumberOfHoursToRescheduleRedial_si, "
                                        + "     TransferStatusId_ti, "
                                        + "     IsHangUpDetected_ti, "
                                        + "     IsOptOut_ti, "
                                        + "     IsMaxRedialsReached_ti, "
                                        + "     IsRescheduled_ti, "
                                        + "     CallResult_int, "
                                        + "     SixSecondBilling_int, "
                                        + "     SystemBilling_int, "
                                        + "     RXCDLStartTime_dt, "
                                        + "     CallStartTime_dt, "
                                        + "     CallEndTime_dt, "
                                        + "     CallStartTimeLiveTransfer_dt, "
                                        + "     CallEndTimeLiveTransfer_dt, "
                                        + "     CallResultTS_dt, "
                                        + "     PlayFileStartTime_dt, "
                                        + "     PlayFileEndTime_dt, "
                                        + "     HangUpDetectedTS_dt, "
                                        + "     Created_dt, "
                                        + "     DialerName_vch, "
                                        + "     CurrTS_vch, "
                                        + "     CurrVoice_vch, "
                                        + "     CurrTSLiveTransfer_vch, "
                                        + "     CurrVoiceLiveTransfer_vch, "
                                        + "     CurrCDP_vch, "
                                        + "     CurrCDPLiveTransfer_vch, "
                                        + "     DialString_vch, "
                                        + "     RedialNumber_int, "
                                        + "     TimeZone_ti, "
                                        + "     MessageDelivered_si, "
                                        + "     SingleResponseSurvey_si, "
                                        + "     ReplayTotalCallTime_int, "
                                        + "     XMLResultStr_vch, "
                                        + "     TotalConnectTime_int, "
                                        + "     IsOptIn_ti, "
                                        + "     FileSeqNumber_int, "
                                        + "     UserSpecifiedData_vch, "
                                        + "     XMLControlString_vch, "
                                        + "     DTS_UUID_vch, "
                                        + "     MainMessageLengthSeconds_int       "
                                        + " FROM " 
                                        + "     calldetail.rxcalldetails_test "
                                        + " WHERE "
                                        + "     CallDetailsStatusId_ti = " + ESID                        
                                        + "     AND RXCallDetailId_int MOD " + NumberOfResultsThreads + " = " +  CurrModValue                                          
                                        + " ORDER BY RXCallDetailId_int ASC  "
                                        + " LIMIT " + NumberOfResultsContactsToProcessPerThread ;


                //SelectResultsStmt = connMain.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
                
                SelectResultsStmt = MainConnection[i].createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
                SelectResultsRS = SelectResultsStmt.executeQuery(QueryString);

                int CurrentBillingAmount = 0;
                              
                int CurrentRowCount = 0;
                String QueryStringInsertFromRemote = "";
                
                // Now do something with the ResultSet ....
                while ( SelectResultsRS.next( ) && !Thread.interrupted()) 
                {// While SelectResultsRS
                    CurrentRowCount++;
                    
                    // Allow thread to be canceled 
                    if (isCancelled()) 
                    {
                        // Do any additional clean up here - maybe update main DB of non-processed?     
                         updateMessage("Cancelled");
                         break;
                    }
                     
                    // When a progress is bound (.bind()) to this task - this will update the progress meter        
                    updateProgress(SelectResultsRS.getRow(), NumberOfResultsContactsToProcessPerThread);
                    updateMessage("Thread " + CurrModValue + " " + SelectResultsRS.getInt("DTSId_int"));
                  
                    // Get Billing amount - need billing method in JAVA
                    CurrentBillingAmount = 0;
                    

                //    System.out.println(SelectResultsRS.getInt("DTSId_int"));
                        
                   QueryStringInsertFromRemote =      " INSERT INTO SimpleXResults.ContactResults_test "
                    + " ( "	                           
                        + " MasterRXCallDetailId_int, "                                    
	                + " RXCallDetailId_int, "
                        + " DTSID_int, "
                        + " BatchId_bi, "
                        + " PhoneId_int, "
                        + " TotalObjectTime_int, "
                        + " TotalCallTimeLiveTransfer_int, "
                        + " TotalCallTime_int, "
                        + " TotalConnectTime_int, "
                        + " ReplayTotalCallTime_int, "
                        + " TotalAnswerTime_int, "
                        + " UserSpecifiedLineNumber_si, "
                        + " NumberOfHoursToRescheduleRedial_si, "
                        + " TransferStatusId_ti, "
                        + " IsHangUpDetected_ti, "
                        + " IsOptOut_ti, "
                        + " IsMaxRedialsReached_ti, "
                        + " IsRescheduled_ti, "
                        + " CallResult_int, "
                        + " SixSecondBilling_int, "
                        + " SystemBilling_int, "
                        + " RXCDLStartTime_dt, "
                        + " CallStartTime_dt, "
                        + " CallEndTime_dt, "
                        + " CallStartTimeLiveTransfer_dt, "
                        + " CallEndTimeLiveTransfer_dt, "
                        + " CallResultTS_dt, "
                        + " PlayFileStartTime_dt, "
                        + " PlayFileEndTime_dt, "
                        + " HangUpDetectedTS_dt, "
                        + " Created_dt, "
                        + " DialerName_vch, "
                        + " DialerIP_vch, "
                        + " CurrTS_vch, "
                        + " CurrVoice_vch, "
                        + " CurrTSLiveTransfer_vch, "
                        + " CurrVoiceLiveTransfer_vch, "
                        + " CurrCDP_vch, "
                        + " CurrCDPLiveTransfer_vch, "
                        + " ContactString_vch, "
                        + " RedialNumber_int, "
                        + " TimeZone_ti, "
                        + " MessageDelivered_si, "
                        + " SingleResponseSurvey_si, "
                        + " XMLResultStr_vch, "
                        + " IsOptIn_ti, "
                        + " ActualCost_int, "
                        + " DTS_UUID_vch, "
                        + " XMLControlString_vch, "
                        + " UserSpecifiedData_vch, "
                        + " FileSeqNumber_int, "
                        + " MainMessageLengthSeconds_int "
                    + " ) "
                    + " VALUES "
                    + " ( "
                        + " NULL, "
                        + " " + SelectResultsRS.getInt("RXCallDetailId_int") + ", " //	#ExtractFromDialer.RXCallDetailId_int#,
                        + " " + SelectResultsRS.getInt("DTSID_int") + ", " //#ExtractFromDialer.DTSID_int#,
                        + " " + SelectResultsRS.getInt("BatchId_bi") + ", " //#ExtractFromDialer.BatchId_bi#,
                        + " " + SelectResultsRS.getInt("PhoneId_int") + ", " //#ExtractFromDialer.PhoneId_int#,
                        + " " + SelectResultsRS.getInt("TotalObjectTime_int") + ", " //#ExtractFromDialer.TotalObjectTime_int#,
                        + " " + SelectResultsRS.getInt("TotalCallTimeLiveTransfer_int") + ", " //#ExtractFromDialer.TotalCallTimeLiveTransfer_int#,
                        + " " + SelectResultsRS.getInt("TotalCallTime_int") + ", " //#ExtractFromDialer.TotalCallTime_int#,
                        + " " + SelectResultsRS.getInt("TotalConnectTime_int") + ", " //#ExtractFromDialer.TotalConnectTime_int#,
                        + " " + SelectResultsRS.getInt("ReplayTotalCallTime_int") + ", " //#ExtractFromDialer.ReplayTotalCallTime_int#,
                        + " " + SelectResultsRS.getInt("TotalAnswerTime_int") + ", " //#ExtractFromDialer.TotalAnswerTime_int#,
                        + " " + SelectResultsRS.getInt("UserSpecifiedLineNumber_si") + ", " //#ExtractFromDialer.UserSpecifiedLineNumber_si#,
                        + " " + SelectResultsRS.getInt("NumberOfHoursToRescheduleRedial_si") + ", " //#ExtractFromDialer.NumberOfHoursToRescheduleRedial_si#,
                        + " " + SelectResultsRS.getInt("TransferStatusId_ti") + ", " //#ExtractFromDialer.TransferStatusId_ti#,
                        + " " + SelectResultsRS.getInt("IsHangUpDetected_ti") + ", " //#ExtractFromDialer.IsHangUpDetected_ti#,
                        + " " + SelectResultsRS.getInt("IsOptOut_ti") + ", " //#ExtractFromDialer.IsOptOut_ti#,
                        + " " + SelectResultsRS.getInt("IsMaxRedialsReached_ti") + ", " //#ExtractFromDialer.IsMaxRedialsReached_ti#,
                        + " " + SelectResultsRS.getInt("IsRescheduled_ti") + ", " //#ExtractFromDialer.IsRescheduled_ti#,
                        + " " + SelectResultsRS.getInt("CallResult_int") + ", " //#ExtractFromDialer.CallResult_int#,
                        + " " + SelectResultsRS.getInt("SixSecondBilling_int") + ", " //#ExtractFromDialer.SixSecondBilling_int#,
                        + " " + SelectResultsRS.getInt("SystemBilling_int") + ", " //#ExtractFromDialer.SystemBilling_int#,
                        + " '" + SelectResultsRS.getString("RXCDLStartTime_dt") + "', " //'#ExtractFromDialer.RXCDLStartTime_dt#',
                        + " '" + SelectResultsRS.getString("CallStartTime_dt") + "', " //'#ExtractFromDialer.CallStartTime_dt#',
                        + " '" + SelectResultsRS.getString("CallEndTime_dt") + "', " //'#ExtractFromDialer.CallEndTime_dt#',
                        + " '" + SelectResultsRS.getString("CallStartTimeLiveTransfer_dt") + "', " //'#ExtractFromDialer.CallStartTimeLiveTransfer_dt#',
                        + " '" + SelectResultsRS.getString("CallEndTimeLiveTransfer_dt") + "', " //'#ExtractFromDialer.CallEndTimeLiveTransfer_dt#',
                        + " '" + SelectResultsRS.getString("CallResultTS_dt") + "', " //'#ExtractFromDialer.CallResultTS_dt#',
                        + " '" + SelectResultsRS.getString("PlayFileStartTime_dt") + "', " //'#ExtractFromDialer.PlayFileStartTime_dt#',
                        + " '" + SelectResultsRS.getString("PlayFileEndTime_dt") + "', " //'#ExtractFromDialer.PlayFileEndTime_dt#',
                        + " '" + SelectResultsRS.getString("HangUpDetectedTS_dt") + "', " //'#ExtractFromDialer.HangUpDetectedTS_dt#',
                        + " '" + SelectResultsRS.getString("Created_dt") + "', " //'#ExtractFromDialer.Created_dt#',
                        + " '" + SelectResultsRS.getString("DialerName_vch") + "', " //'#ExtractFromDialer.DialerName_vch#',
                        + " '" +  RemoteIPAddress[i] + "', " //'#inpDialerIPAddr#',
                        + " '" + SelectResultsRS.getString("CurrTS_vch") + "', " //'#ExtractFromDialer.CurrTS_vch#',
                        + " '" + SelectResultsRS.getString("CurrVoice_vch") + "', " //'#ExtractFromDialer.CurrVoice_vch#',
                        + " '" + SelectResultsRS.getString("CurrTSLiveTransfer_vch") + "', " //'#ExtractFromDialer.CurrTSLiveTransfer_vch#',
                        + " '" + SelectResultsRS.getString("CurrVoiceLiveTransfer_vch") + "', " //'#ExtractFromDialer.CurrVoiceLiveTransfer_vch#',
                        + " '" + SelectResultsRS.getString("CurrCDP_vch") + "', " //'#ExtractFromDialer.CurrCDP_vch#',
                        + " '" + SelectResultsRS.getString("CurrCDPLiveTransfer_vch") + "', " //'#ExtractFromDialer.CurrCDPLiveTransfer_vch#',
                        + " '" + escapeSQL(SelectResultsRS.getString("DialString_vch")) + "', " //'#ExtractFromDialer.DialString_vch#',
                        + " " + SelectResultsRS.getInt("RedialNumber_int") + ", " //#ExtractFromDialer.RedialNumber_int#,
                        + " " + SelectResultsRS.getInt("TimeZone_ti") + ", " //#ExtractFromDialer.TimeZone_ti#,
                        + " " + SelectResultsRS.getInt("MessageDelivered_si") + ", " //#ExtractFromDialer.MessageDelivered_si#,
                        + " " + SelectResultsRS.getInt("SingleResponseSurvey_si") + ", " //#ExtractFromDialer.SingleResponseSurvey_si#,
                        + " '" + escapeSQL(SelectResultsRS.getString("XMLResultStr_vch")) + "', " //<CFQUERYPARAM CFSQLTYPE="CF_SQL_VARCHAR" VALUE="#ExtractFromDialer.XMLResultStr_vch#">,
                        + " " + SelectResultsRS.getInt("IsOptIn_ti") + ", " //#ExtractFromDialer.IsOptIn_ti#,
                        + " " + CurrentBillingAmount + ", " //#CurrentBillingAmount#,
                        + " '" + SelectResultsRS.getString("DTS_UUID_vch") + "', " //'#ExtractFromDialer.DTS_UUID_vch#',
                        + " '" + escapeSQL(SelectResultsRS.getString("XMLControlString_vch")) + "', " // <CFQUERYPARAM CFSQLTYPE="CF_SQL_VARCHAR" VALUE="#ExtractFromDialer.XMLControlString_vch#">,
                        + " '" + escapeSQL(SelectResultsRS.getString("UserSpecifiedData_vch")) + "', " // <CFQUERYPARAM CFSQLTYPE="CF_SQL_VARCHAR" VALUE="#ExtractFromDialer.UserSpecifiedData_vch#">,
                        + " " + SelectResultsRS.getInt("FileSeqNumber_int") + ", " // <cfif ExtractFromDialer.FileSeqNumber_int NEQ "">#ExtractFromDialer.FileSeqNumber_int#<cfelse>NULL</cfif>,
                        + " " + SelectResultsRS.getInt("MainMessageLengthSeconds_int") + " " //#ExtractFromDialer.MainMessageLengthSeconds_int#                        
                        + " ) ";
                    
                    
                    SelectResultsRS.updateInt( "CallDetailsStatusId_ti", abs(ESID) );
                                     
                           
                   
                    InsertRemoteResultsStmt = connRemote.createStatement();
                    InsertRemoteResultsStmt.executeUpdate(QueryStringInsertFromRemote);

                    // reset string to empty
                    QueryStringInsertFromRemote = "";

                    SelectResultsRS.updateRow( );                        

                    
                  
                  

                }// While SelectResultsRS

                // Execute Insert on any remainging records
                if(QueryStringInsertFromRemote.length() > 0)
                {
                    InsertRemoteResultsStmt = connRemote.createStatement();
                    InsertRemoteResultsStmt.executeUpdate(QueryStringInsertFromRemote);  
                    
                    QueryStringInsertFromRemote = "";
                    
                    SelectResultsRS.updateRow( );
                }
                
                

                if(CurrentRowCount == 0)
                {
                    // Write to log that there was nothing to process
                    System.out.println("No results found this loop");
                                      
                    // Only sleep while listening for cancel task/thread calls
                    try 
                    {
                        Thread.sleep(100);
                    }
                    catch (InterruptedException interrupted) 
                    {
                        if (isCancelled()) 
                        {
                            System.out.println("QRC Cancelled");
                            // break;
                        }
                    }
                    
                    
                }
                
                    


                done = true;
            } 
            
            catch (SQLException ex) 
            {
                 // handle any errors
                 System.out.println("SQLException: " + ex.getMessage());
                 System.out.println("SQLState: " + ex.getSQLState());
                 System.out.println("VendorError: " + ex.getErrorCode());
                 i++;
            }
            finally 
            {
                // it is a good idea to release
                // resources in a finally{} block
                // in reverse-order of their creation
                // if they are no-longer needed

                if (SelectResultsRS != null) 
                {
                    try
                    {
                        SelectResultsRS.close();
                    }
                    catch (SQLException sqlEx) 
                    { 

                    } // ignore

                    SelectResultsRS = null;
                }

                if (SelectResultsStmt != null) 
                {
                    try 
                    {
                       SelectResultsStmt.close();
                    }
                    catch (SQLException sqlEx) 
                    { 

                    } // ignore

                    SelectResultsStmt = null;
                }

                if (UpdateResultsStmt != null) 
                {
                    try 
                    {
                       UpdateResultsStmt.close();
                    }
                    catch (SQLException sqlEx) 
                    { 

                    } // ignore

                    UpdateResultsStmt = null;
                }
                                        
                if (InsertRemoteResultsStmt != null) 
                {
                    try 
                    {
                       InsertRemoteResultsStmt.close();
                    }
                    catch (SQLException sqlEx) 
                    { 

                    } // ignore

                    InsertRemoteResultsStmt = null;
                }        
                        
                
            }

               
            QRVC.ResultsReaderCallBackonComplete(CurrModValue);
                    
             return iterations;
         }
 
         }
         
 }