Database event listeners enable Process Manager to use databases to initiate workflow processes. A database event listener monitors its designated data source and initiates the process whenever the predefined conditions are met.
To set up your database event listener, you first need to select which workflow to initiate when the conditions of the event listener are met. Then you provide the name and authentication information for the ODBC database connection on the server where the servicehost is installed. Once you've specified the database, you need to configure the query settings, which tells the database where to look for new records, what to specifically look for, and what to do with new records.
The first query setting is the select statement. The first part of the select statement specifies the record or record type for the database listener to watch for. The second part specifies one or more tables and columns in the database for the event listener to monitor. Finally, it defines the status or state of the column. The syntax of your select statement should resemble the following:
select * from CallLog where CallStatus ='Open'
In this example, CallLog is the table and CallStatus the column. The database returns any record from the designated table and column currently in an open state.
Note: If you don't know the name of the column, you can enter a select statement for the table(s) and click Get database columns, which will give you a list of columns. Then you can complete your select statement with the appropriate column(s). You can use the columns list as well to help you create the update statement.
The second query setting to configure is the update statement. The update statement enables you to change the status of the record, so it can be removed from the queue and not be initiated again. The syntax of your update statement should resemble the following:
update CallLog set CallStatus ='Pending' where CallID={|CallID|}
In this example, the first part of the update statement changes the status of the CallStatus column in the CallLog table from open to pending. The second part of the statement tells the database which record to update. The syntax of the where clause tells the database to use the value of the column ({|CallID|}) from the select statement to know which record to update. Now, when the event listener runs the first query again, a workflow won't be initiated for the same record since it's no longer in an open state.
Finally, you need to select or provide an external system identifier. You select a database column, which is actually a cell or container of a value. Process Manager pulls that value and inserts into the listener. The value serves as the external system identifier within all Process Manager applications. The external system identifier pinpoints the application that initiated the workflow and serves as a reference number to the client application. By having this unique reference number to the client application, Process Manager knows where to obtain the most current information from the database and can continually pull up-to-date information at each stage of the workflow process.
Note: The external system identifier should normally be a unique value. If an earlier record exists with the same external system identifier, it will be terminated when the new record initiates a workflow process. You should only intentionally use a duplicate external system identifier if you want to terminate the previous instance of the workflow process.
Once you start the database listener, it continually runs the query and watches for new records in the database column(s). Each time a value is returned from the query, the listener initiates a workflow process.
You can also use the Spin box to indicate the interval (in minutes) at which you want the listener to poll the database.