我有以下代码,其中增量命令未按预期工作。一旦选择了下面的单选按钮,我将从产品的 txt 框中获取值并执行 RPC。根据输出,我想形成 where 子句并运行结果查询。
我有以下类变量
private static boolean isLoaded = false;
StringBuilder whereClause = new StringBuilder("select * from grocery_shop where ");
StringBuilder productCode = new StringBuilder("(");
ArrayList<String> productList = null;
下面的代码是增量命令中调用RPC的地方
if (Dialog.getRadioproduct().getValue()) {
DeferredCommand.addCommand(new IncrementalCommand() {
@Override
public boolean execute() {
if (isLoaded) {
ProductServiceAsync Service =
ServiceFactory.getService(ProductReportService.class);
Service.getBasicProducts(Dialog.getTxtProduct().getValue(),
new AsyncCallback<ArrayList<String>>() {
@Override
public void onServiceFailure(Throwable ex) {
showError("Error");
}
@Override
public void onServiceSuccess(ArrayList<String> result) {
productList = result;
while(productList.iterator.hasnext())
whereClause.append(" AND PROD = '" + productList.iterator.next() + "'");
isLoaded = true;
}
});
return false;
}
return true;
}
});
}
我希望在上面的 RPC 成功之后执行这个执行查询,但是下面的行是在 RPC 之前执行的。
ResultSet rs = stmt.executeQuery(whereClause);
如果有什么我错过的,请告诉我。