Drools Slow进行批量处理

时间:2014-03-11 07:05:43

标签: drools drools-guvnor drools-fusion

rule "ReportableRule1"
    dialect "mvel"
        when
            rp : repoio( country == null )
        then
            rp.setOrigBuySellFlag( "E" );
        System.out.println("This is the exception of rule1");
    end.

嗨,史蒂夫, 这是我们创建的示例规则。其他规则也几乎相同。

KieServices ks = KieServices.Factory.get();
KieContainer kContainer = ks.getKieClasspathContainer();
KieSession kSession = kContainer.newKieSession("ksession-rules");

我的主要类是使用这个代码,因为我们正在使用KIE A​​PI。可以有任何其他方法来设计快速处理规则。只能设置和获取.next。这是我设置和获取的主要课程。

public static final void main(String[] args) {
        try {
            // load up the knowledge base
              KieServices ks = KieServices.Factory.get();
          KieContainer kContainer = ks.getKieClasspathContainer();
            KieSession kSession = kContainer.newKieSession("ksession-rules");
            // go !

            HRFReportableVO rp=new HRFReportableVO();
            rp.setDefaultSystemFlag("true");
            rp.setDefaultCntrPartyFlag("true");
            rp.setSecurity("NL0010060257");
            rp.setTradeType("SALES_TRADER");
            rp.setTradeSubType("ALLOC_BLOCK");
            rp.setBoClientAcctId("fsd");
            rp.setSubtypec(null);
            rp.setSysClientAccId("DROPCTL2");
            rp.checkFutureDate("2013-12-27", "2012-01-03");
            rp.setCountryOfInc("DEU");
            rp.setTransactiontype("S");
            String abc="-50.90";
            double amount = Double.parseDouble(abc);
            rp.setInvalidQuantity(amount);
            rp.setActid("xsd");
            rp.setDealerID("SBILGB2LXXX");
            rp.setMonth(0);
            rp.setYear(2012);
            rp.setChecktrade(1);
            rp.setCounterPart(14);
            rp.setCountry("AFG");
            rp.setSystem(14);
            rp.matchDate("yyyy-MM-dd", "12-12-2013");
            rp.checkDate("2013-12-12");
            rp.setTypc("GOVT");
            rp.setInsttypc("SEC");
            //rp.setTradeDate(null);
            //rp.setTradeDate(new Date(System.currentTimeMillis()));
            rp.setOrigBuySellFlag("A");
            rp.setLglEntyCd("2");
            rp.setIscrcy("EUR");
            rp.setIscntry("GBR");
            rp.setGermany_reportable_flag("Y");
            kSession.insert(rp);
            kSession.fireAllRules();
            System.out.println(rp.getExceptionDescription());
            System.out.println(rp.getFlag());
        } catch (Throwable t) {
            t.printStackTrace();
        }

}

我们已将Drool规则与Talend ETL集成在一起。 Talend ETL开发人员说他已经通过使用类似于我在主类中显示的代码的Setter和getters方法将值传递给了Drool规则。这里的问题是我们的经理说,流口水将一条记录与规则进行比较,然后给出该记录的结果。他要求我改变代码,以便Drool获取更多记录,并在批次中给出结果,以便处理变得快速。

0 个答案:

没有答案