Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
Objective: Demonstrate simple database write operations with the DBReport mediator /wiki/spaces/EI6xx/pages/49612763.
Code Block | ||
---|---|---|
| ||
<definitions xmlns="http://ws.apache.org/ns/synapse"> <sequence name="main"> <in> <send> <endpoint> <address uri="http://localhost:9000/services/SimpleStockQuoteService"/> </endpoint> </send> </in> <out> <log level="custom"> <property name="text" value="** Reporting to the Database **"/> </log> <dbreport xmlns="http://ws.apache.org/ns/synapse"> <connection> <pool> <driver>org.apache.derby.jdbc.ClientDriver</driver> <url>jdbc:derby://localhost:1527/esbdb;create=false</url> <user>esb</user> <password>esb</password> </pool> </connection> <statement> <sql>update company set price=? where name =?</sql> <parameter expression="//m0:return/m1:last/child::text()" xmlns:m0="http://services.samples" xmlns:m1="http://services.samples/xsd" type="DOUBLE"/> <parameter expression="//m0:return/m1:symbol/child::text()" xmlns:m0="http://services.samples" xmlns:m1="http://services.samples/xsd" type="VARCHAR"/> </statement> </dbreport> <send/> </out> </sequence> </definitions> |
Prerequisites:
- Create the above configuration and deploy it in the WSO2 EI profile, seeĀ Working with WSO2 Integration Studio.
- Start the Axis2 server and deploy the SimpleStockQuoteService if not already done
The dbreport mediator writes (inserts one row) to a table using the message details. It works the same as the DBLookup mediator /wiki/spaces/EI6xx/pages/49612755. In this sample, the DBReport mediator is used for updating the stock price of the company using the last quote value, which is calculated by evaluating an XPath against the response message. After running this sample, user can check the company table using the Derby client tool. It will show the value inserted by the DBReport mediator.
...