我执行这个我的代码,我不明白为什么循环的经过时间非常高。
有两个循环。Invoices 表上的第一个循环和 InvoicesLignes 表上的 seconde 循环。
InvoicesLignes 表有一个索引“Code”,它是 Invoice 的“外键”。在数据库 Access 中,Invoices 和 InvoicesLines 之间存在关系,但未定义外键,我无法使用 Joiner 类。我无法修改数据库。
import java.io.File;
import java.util.Date;
import java.io.IOException;
import com.healthmarketscience.jackcess.*;
class MultipleLoop {
public static void main(String[] args) {
File jfile = new File("/project/database.mdb");
Date start_date= new Date("2013/01/01");
Date end_date= new Date("2013/12/31");
try {
Database db = DatabaseBuilder.open(jfile);
Table invoices = db.getTable("Invoices");
Table invoices_lignes = db.getTable("InvoiceLignes");
Cursor cursor = CursorBuilder.createCursor(invoices_lignes.getIndex("Code"));
for(Row invoice : invoices) {
if ((start_date.before((Date)invoice.get("Date"))
|| start_date.equals((Date)invoice.get("Date")))
&&
(end_date.after((Date)invoice.get("Date"))
|| end_date.equals((Date)invoice.get("Date")) )) {
System.out.println(String.format("Invoice id : '%s' time : '%s'",
invoice.get("Code"),
System.currentTimeMillis( ) ));
long start = System.currentTimeMillis( );
for (Row invoice_ligne : cursor.newIterable().addMatchPattern("Code",
invoice.get("Code")))
{
System.out.println(String.format("Loop time : '%s'",
System.currentTimeMillis( )));
}
long end = System.currentTimeMillis( );
System.out.println(String.format("\n\nEnd loop time : '%s'",
System.currentTimeMillis( )));
long diff = end - start;
System.out.println(String.format("Loop elapsed time : '%s' ms\n\n",
diff ));
}
}
} catch (IOException e) {
//} catch (Exception e) {
System.out.println(e);
}
}
}
我的日志是
Invoice id : '19901/79018' time : '1411043140236'
Loop time : '1411043140237'
Loop time : '1411043140237'
Loop time : '1411043140237'
Loop time : '1411043140237'
End loop time : '1411043141335'
Loop elapsed time : '1098' ms
Invoice id : '138901/909719' time : '1411043141335'
Loop time : '1411043141336'
Loop time : '1411043141336'
End loop time : '1411043142418'
Loop elapsed time : '1083' ms
Invoice id : '1309091/729090' time : '1411043142419'
Loop time : '1411043142419'
Loop time : '1411043142419'
End loop time : '1411043143515'
Loop elapsed time : '1096' ms
我不明白为什么循环的经过时间非常高
感谢您的帮助