int run_scan(){ int iter = g_paramters[P_LOOPS].value; NDB_TICKS start1, stop; int sum_time= 0; Uint32 sample_rows = 0; int tot_rows = 0; NDB_TICKS sample_start = NdbTick_CurrentMillisecond(); Uint32 tot = g_paramters[P_ROWS].value; if(g_paramters[P_BOUND].value >= 2 || g_paramters[P_FILT].value == 2) iter *= g_paramters[P_ROWS].value; NdbScanOperation * pOp = 0; NdbIndexScanOperation * pIOp = 0; NdbConnection * pTrans = 0; int check = 0; for(int i = 0; i<iter; i++){ start1 = NdbTick_CurrentMillisecond(); pTrans = pTrans ? pTrans : g_ndb->startTransaction(); if(!pTrans){ g_err << "Failed to start transaction" << endl; err(g_ndb->getNdbError()); return -1; } int par = g_paramters[P_PARRA].value; int bat = g_paramters[P_BATCH].value; NdbScanOperation::LockMode lm; switch(g_paramters[P_LOCK].value){ case 0: lm = NdbScanOperation::LM_CommittedRead; break; case 1: lm = NdbScanOperation::LM_Read; break; case 2: lm = NdbScanOperation::LM_Exclusive; break; default: abort(); } NdbScanOperation::ScanOptions options; bzero(&options, sizeof(options)); options.optionsPresent= NdbScanOperation::ScanOptions::SO_SCANFLAGS | NdbScanOperation::ScanOptions::SO_PARALLEL | NdbScanOperation::ScanOptions::SO_BATCH; bool ord= g_paramters[P_ACCESS].value == 2; bool mrr= (g_paramters[P_ACCESS].value != 0) && (g_paramters[P_BOUND].value == 3); options.scan_flags|= ( ord ? NdbScanOperation::SF_OrderBy:0 ) | ( mrr ? NdbScanOperation::SF_MultiRange:0 ); options.parallel= par; options.batch= bat; switch(g_paramters[P_FILT].value){ case 0: // All break; case 1: // None break; case 2: // 1 row default: { assert(g_table->getNoOfPrimaryKeys() == 1); // only impl. so far abort(); #if 0 int tot = g_paramters[P_ROWS].value; int row = rand() % tot; NdbInterpretedCode* ic= new NdbInterpretedCode(g_table); NdbScanFilter filter(ic); filter.begin(NdbScanFilter::AND); filter.eq(0, row); filter.end(); options.scan_flags|= NdbScanOperation::SF_Interpreted; options.interpretedCode= ⁣ break; #endif } } if(g_paramters[P_ACCESS].value == 0){ pOp = pTrans->scanTable(g_table_record, lm, NULL, // Mask &options, sizeof(NdbScanOperation::ScanOptions)); assert(pOp); } else { pOp= pIOp= pTrans->scanIndex(g_index_record, g_table_record, lm, NULL, // Mask NULL, // First IndexBound &options, sizeof(NdbScanOperation::ScanOptions)); if (pIOp == NULL) { err(pTrans->getNdbError()); abort(); } assert(pIOp); switch(g_paramters[P_BOUND].value){ case 0: // All break; case 1: // None check= setEqBound(pIOp, g_index_record, 0, 0); assert(check == 0); break; case 2: { // 1 row default: assert(g_table->getNoOfPrimaryKeys() == 1); // only impl. so far int tot = g_paramters[P_ROWS].value; int row = rand() % tot; check= setEqBound(pIOp, g_index_record, row, 0); assert(check == 0); break; } case 3: { // read multi int multi = g_paramters[P_MULTI].value; int tot = g_paramters[P_ROWS].value; int rangeStart= i; for(; multi > 0 && i < iter; --multi, i++) { int row = rand() % tot; /* Set range num relative to this set of bounds */ check= setEqBound(pIOp, g_index_record, row, i- rangeStart); if (check != 0) { err(pIOp->getNdbError()); abort(); } assert(check == 0); } break; } } } assert(pOp); assert(check == 0); int rows = 0; check = pTrans->execute(NoCommit); assert(check == 0); int fetch = g_paramters[P_FETCH].value; const char * result_row_ptr; while((check = pOp->nextResult(&result_row_ptr, true, false)) == 0){ do { rows++; } while(!fetch && ((check = pOp->nextResult(&result_row_ptr, false, false)) == 0)); if(check == -1){ err(pTrans->getNdbError()); return -1; } assert(check == 2); } if(check == -1){ err(pTrans->getNdbError()); return -1; } assert(check == 1); pTrans->close(); pTrans = 0; stop = NdbTick_CurrentMillisecond(); int time_passed= (int)(stop - start1); sample_rows += rows; sum_time+= time_passed; tot_rows+= rows; if(sample_rows >= tot) { int sample_time = (int)(stop - sample_start); g_info << "Found " << sample_rows << " rows" << endl; g_err.println("Time: %d ms = %u rows/sec", sample_time, (1000*sample_rows)/sample_time); sample_rows = 0; sample_start = stop; } } g_err.println("Avg time: %d ms = %u rows/sec", sum_time/tot_rows, (1000*tot_rows)/sum_time); return 0; }