IDEMPIERE-496 Exception when changing Organization Info. Performance improvement.
This commit is contained in:
parent
a4fc8c40be
commit
41249300e7
|
@ -36,6 +36,7 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.concurrent.Future;
|
import java.util.concurrent.Future;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
import javax.swing.event.TableModelListener;
|
import javax.swing.event.TableModelListener;
|
||||||
|
@ -1011,9 +1012,9 @@ public class GridTable extends AbstractTableModel
|
||||||
log.fine("Waiting for loader row=" + row + ", size=" + m_sort.size());
|
log.fine("Waiting for loader row=" + row + ", size=" + m_sort.size());
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Thread.sleep(500); // 1/2 second
|
m_loaderFuture.get(500, TimeUnit.MILLISECONDS);
|
||||||
}
|
}
|
||||||
catch (InterruptedException ie)
|
catch (Exception ie)
|
||||||
{}
|
{}
|
||||||
loops++;
|
loops++;
|
||||||
}
|
}
|
||||||
|
@ -3318,6 +3319,8 @@ public class GridTable extends AbstractTableModel
|
||||||
private ResultSet m_rs = null;
|
private ResultSet m_rs = null;
|
||||||
private Trx trx = null;
|
private Trx trx = null;
|
||||||
private Properties m_context = null;
|
private Properties m_context = null;
|
||||||
|
private int maxRows;
|
||||||
|
private int rows;
|
||||||
|
|
||||||
public void setContext(Properties context)
|
public void setContext(Properties context)
|
||||||
{
|
{
|
||||||
|
@ -3331,9 +3334,10 @@ public class GridTable extends AbstractTableModel
|
||||||
*/
|
*/
|
||||||
protected int open (int maxRows)
|
protected int open (int maxRows)
|
||||||
{
|
{
|
||||||
// log.config( "MTable Loader.open");
|
this.maxRows = maxRows;
|
||||||
|
|
||||||
// Get Number of Rows
|
// Get Number of Rows
|
||||||
int rows = 0;
|
rows = 0;
|
||||||
PreparedStatement pstmt = null;
|
PreparedStatement pstmt = null;
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
try
|
try
|
||||||
|
@ -3361,7 +3365,20 @@ public class GridTable extends AbstractTableModel
|
||||||
info.append(rows);
|
info.append(rows);
|
||||||
if (rows == 0)
|
if (rows == 0)
|
||||||
info.append(" - ").append(m_SQL_Count);
|
info.append(" - ").append(m_SQL_Count);
|
||||||
|
|
||||||
|
if (maxRows > 0 && rows > maxRows)
|
||||||
|
{
|
||||||
|
info.append(" - MaxRows=").append(maxRows);
|
||||||
|
rows = maxRows;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (log.isLoggable(Level.FINE))
|
||||||
|
log.fine(info.toString());
|
||||||
|
|
||||||
|
return rows;
|
||||||
|
} // open
|
||||||
|
|
||||||
|
private void openResultSet() {
|
||||||
//postgresql need trx to use cursor based resultset
|
//postgresql need trx to use cursor based resultset
|
||||||
String trxName = m_virtual ? Trx.createTrxName("Loader") : null;
|
String trxName = m_virtual ? Trx.createTrxName("Loader") : null;
|
||||||
trx = trxName != null ? Trx.get(trxName, true) : null;
|
trx = trxName != null ? Trx.get(trxName, true) : null;
|
||||||
|
@ -3369,11 +3386,9 @@ public class GridTable extends AbstractTableModel
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
m_pstmt = DB.prepareStatement(m_SQL, trxName);
|
m_pstmt = DB.prepareStatement(m_SQL, trxName);
|
||||||
if (maxRows > 0 && rows > maxRows)
|
if (this.maxRows > 0 && rows > this.maxRows)
|
||||||
{
|
{
|
||||||
m_pstmt.setMaxRows(maxRows);
|
m_pstmt.setMaxRows(this.maxRows);
|
||||||
info.append(" - MaxRows=").append(maxRows);
|
|
||||||
rows = maxRows;
|
|
||||||
}
|
}
|
||||||
//ensure not all row is fectch into memory for virtual table
|
//ensure not all row is fectch into memory for virtual table
|
||||||
if (m_virtual)
|
if (m_virtual)
|
||||||
|
@ -3384,11 +3399,8 @@ public class GridTable extends AbstractTableModel
|
||||||
catch (SQLException e)
|
catch (SQLException e)
|
||||||
{
|
{
|
||||||
log.log(Level.SEVERE, m_SQL, e);
|
log.log(Level.SEVERE, m_SQL, e);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
log.fine(info.toString());
|
}
|
||||||
return rows;
|
|
||||||
} // open
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Close RS and Statement
|
* Close RS and Statement
|
||||||
|
@ -3419,7 +3431,7 @@ public class GridTable extends AbstractTableModel
|
||||||
} // run
|
} // run
|
||||||
|
|
||||||
private void doRun() {
|
private void doRun() {
|
||||||
log.info("");
|
openResultSet();
|
||||||
if (m_rs == null)
|
if (m_rs == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue