簡體   English   中英

如何將數據庫(MySql)與drools項目連接?

[英]How to connect a Database(MySql) with drools project?

我創建了三個類,並嘗試通過將其連接到數據庫來通過主類設置它們的值。 然后,我試圖解散規則,但沒有得到輸出。 我必須從數據庫中獲取值並將它們設置為三個類的變量。

static int pid;
static int mrp;
static int cid;
static float tax;
static String pname;
static String cname;
public static void main(String[] args)
{

    try
    {
    Class.forName("com.mysql.jdbc.Driver");
    Connection cn=DriverManager.getConnection("jdbc:mysql://localhost:3306/abhi","root","abhinav");
    Statement ps=cn.createStatement()   ;
    ResultSet rs=ps.executeQuery("select * from product ");
    while(rs.next())
    {
     pid=rs.getInt(1);
     pname=rs.getString(2);
    mrp=rs.getInt(3);
    }
    Statement ps1=cn.createStatement();
    ResultSet rs1=ps1.executeQuery("select * from city");


    while(rs1.next())
    {
        cid=rs1.getInt(1);
        cname=rs1.getString(2);
    }
    Statement ps2=cn.createStatement();
    ResultSet rs2=ps2.executeQuery("select * from tax");
    while(rs2.next())
    {
        cid=rs2.getInt(1);
        pid=rs2.getInt(2);
        tax=rs2.getFloat(3);
    }


    KnowledgeBase kbase = readKnowledgeBase();
    StatefulKnowledgeSession ksession = kbase.newStatefulKnowledgeSession();
    Product p=new Product();
    p.setPid(pid);
    p.setPname(pname);
    p.setMrp(mrp);
    ksession.insert(p);
    City c=new City();
    c.setCid(cid);
    c.setCname(cname);
    ksession.insert(c);
    Tax t=new Tax();
    t.setCid(cid);
    t.setPid(pid);
    t.setTax(tax);
    ksession.insert(t);
    ksession.fireAllRules();
    }
    catch(Throwable t)
    {
        t.printStackTrace();
    }

您必須為每個查詢結果插入一個對象作為事實,例如

ResultSet rs=ps.executeQuery("select * from product ");
while(rs.next()){
  int pid = rs.getInt(1);
  String pname = rs.getString(2);
  int mrp = rs.getInt(3);
  Product p = new Product();
  p.setPid(pid);
  p.setPname(pname);
  p.setMrp(mrp);
  ksession.insert(p);
}

// same for City and Tax ...

ksession.fireAllRules();

在使用變量的地方聲明變量。 (對城市和稅收使用全球cid很容易導致錯誤。)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM