[jboss-user] [JBoss jBPM] - Setting up JBoss database for deployment
Hattifnat
do-not-reply at jboss.com
Fri Mar 16 06:14:59 EDT 2007
Hello!
As a fresh Jboss user I came to a problem that is basic probably for most of you, but I cannot find a solution anywhere.
I am using jBPM-starters kit 3.1.4 and working in Eclipse with the JBoss plugin.
I try to create two processes, where one is nested in another as a subflow. The very simplified version of the problem is such:
Super-process:
<?xml version="1.0" encoding="UTF-8"?>
|
| <process-definition
| xmlns="urn:jbpm.org:jpdl-3.1" name="Super">
| <start-state name="start">
| <transition name="" to="process1"></transition>
| </start-state>
| <process-state name="process1">
| <sub-process name="Sub" />
| <transition name="" to="end1"></transition>
| </process-state>
| <end-state name="end1"></end-state>
| </process-definition>
Sub-process:
<?xml version="1.0" encoding="UTF-8"?>
|
| <process-definition
| xmlns="urn:jbpm.org:jpdl-3.1" name="Sub">
| <start-state name="start">
| <transition name="" to="end1"></transition>
| </start-state>
| <end-state name="end1"></end-state>
| </process-definition>
Then I try to run the super-process in a way suggested in this thread:
http://www.jboss.org/index.html?module=bb&op=viewtopic&t=93504
public class Test {
|
| public static void main(String[] args) {
|
| JbpmContext context = JbpmConfiguration.getInstance()
| .createJbpmContext();
|
| try {
| FileInputStream fis_super = new FileInputStream(
| "/path/Eclipse/workspace/SubflowTest/src/main/Super/processdefinition.xml");
| FileInputStream fis_sub = new FileInputStream(
| "/path/Eclipse/workspace/SubflowTest/src/main/Sub/processdefinition.xml");
|
| ProcessDefinition pdload_sub = ProcessDefinition
| .parseXmlInputStream(fis_sub);
| context.deployProcessDefinition(pdload_sub);
|
| ProcessDefinition pdload_super = ProcessDefinition
| .parseXmlInputStream(fis_super);
| context.deployProcessDefinition(pdload_super);
|
| GraphSession gs_caller = context.getGraphSession();
|
| // don't think I necessarily need to reload the process definitions
| // from the session but it doesn't make a difference
| ProcessDefinition pd_sub = gs_caller
| .findLatestProcessDefinition("Sub");
| ProcessDefinition pd_super = gs_caller
| .findLatestProcessDefinition("Super");
|
| ProcessInstance inst = new ProcessInstance(pd_super);
|
| // begin
| Token token = inst.getRootToken();
| ContextInstance contextInst = (ContextInstance) inst
| .getInstance(ContextInstance.class);
|
| System.out.println("getNode().getName(): "
| + token.getNode().getName());
|
| token.signal();
| System.out.println("getNode().getName(): "
| + token.getNode().getName());
| } catch (Exception e) {
| e.printStackTrace();
| } finally {
| context.close();
| }
| }
| }
The result of the execution is the well known "table JBPM_PROCESSDEFINITION not found" error (exactly:
10:49:44,916 [main] DEBUG DbPersistenceService : beginning hibernate transaction
| 10:49:44,959 [main] WARN JDBCExceptionReporter : SQL Error: -22, SQLState: S0002
| 10:49:44,960 [main] ERROR JDBCExceptionReporter : Table not found in statement [select top ? processdef0_.ID_ as ID1_4_, processdef0_.NAME_ as NAME2_4_, processdef0_.VERSION_ as VERSION3_4_, processdef0_.ISTERMINATIONIMPLICIT_ as ISTERMIN4_4_, processdef0_.STARTSTATE_ as STARTSTATE5_4_ from JBPM_PROCESSDEFINITION processdef0_ where processdef0_.NAME_=? order by processdef0_.VERSION_ desc]
| org.hibernate.exception.SQLGrammarException: could not execute query
| at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:65)
| at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
| at org.hibernate.loader.Loader.doList(Loader.java:2153)
| (...)
| Caused by: java.sql.SQLException: Table not found in statement [select top ? processdef0_.ID_ as ID1_4_, processdef0_.NAME_ as NAME2_4_, processdef0_.VERSION_ as VERSION3_4_, processdef0_.ISTERMINATIONIMPLICIT_ as ISTERMIN4_4_, processdef0_.STARTSTATE_ as STARTSTATE5_4_ from JBPM_PROCESSDEFINITION processdef0_ where processdef0_.NAME_=? order by processdef0_.VERSION_ desc]
| at org.hsqldb.jdbc.Util.throwError(Unknown Source)
| at org.hsqldb.jdbc.jdbcPreparedStatement.<init>(Unknown Source)
| at org.hsqldb.jdbc.jdbcConnection.prepareStatement(Unknown Source)
| (...)
| 10:49:44,968 [main] ERROR GraphSession : org.hibernate.exception.SQLGrammarException: could not execute query
| org.jbpm.JbpmException: couldn't find process definition 'Sub'
| at org.jbpm.db.GraphSession.findLatestProcessDefinition(GraphSession.java:157)
| at org.jbpm.db.GraphSession.deployProcessDefinition(GraphSession.java:67)
| at org.jbpm.JbpmContext.deployProcessDefinition(JbpmContext.java:173)
| at Test.main(Test.java:26)
| Caused by: org.hibernate.exception.SQLGrammarException: could not execute query
| at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:65)
| at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
| (...)
| Caused by: java.sql.SQLException: Table not found in statement [select top ? processdef0_.ID_ as ID1_4_, processdef0_.NAME_ as NAME2_4_, processdef0_.VERSION_ as VERSION3_4_, processdef0_.ISTERMINATIONIMPLICIT_ as ISTERMIN4_4_, processdef0_.STARTSTATE_ as STARTSTATE5_4_ from JBPM_PROCESSDEFINITION processdef0_ where processdef0_.NAME_=? order by processdef0_.VERSION_ desc]
| at org.hsqldb.jdbc.Util.throwError(Unknown Source)
| at org.hsqldb.jdbc.jdbcPreparedStatement.<init>(Unknown Source)
| at org.hsqldb.jdbc.jdbcConnection.prepareStatement(Unknown Source)
| (...)
| (I trimmed the log)
So one thing I understood from what I read in the forum and in the Internet - i have to set up the Hibernate database and create a table JBPM_PROCESSDEFINITION. But I couldn't find a hint on how to to it. Can it be done programatticaly? Or how should I do it in any other way (preferably nice and easy :P)?
View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4028719#4028719
Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=4028719
More information about the jboss-user
mailing list