This article describes how to get data from an SQL server database table and use the data to generate an invoice.
In this example, we will create a SharePoint Workflow which gets data from the database table and generates an invoice. The generated invoice will be sent to e-mail recipients, and a copy of the invoice will be saved in a document library. The invoice will be generated and sent as soon as a new item is added into the list.
The invoice will be generated with data received from the following sources:
This workflow cannot be created using only the standard actions and conditions available in SharePoint; we will use several actions provided in HarePoint Workflow Extensions for SharePoint:
The Workflow will start when a new item is added to the SharePoint list, and it will work in the following manner:
Before creation of the Workflow it is necessary to do the following:
Let's start creation of the Workflow.
First, we should add an “Execute SQL Command” action to get data from the database. This action is located in the “HarePoint Activities – Development” category:
The first parameter should contain an SQL request. In our case it would be:
This SQL request returns the e-mail and postal addresses of the client whose name is equal to the client name of the current list item which is added.
The second parameter is a connection string to the SQL Server database. In our example it looks like this:
The third parameter is the type of the database which is used. In our example it is “MS SQL”.
The forth parameter which we should specify is the name of the variable which contains the results.
The last parameter is a variable which contains the number of found strings.
The configured action looks like this:
The next step is to check the resulting data and determine how many records were found by our SQL request.
To check it we will use the “If any value equals value” condition and set the variable “RecordsAffected” (which was filled in by the previous action) as the first parameter. We will make sure that it is equal “1”, otherwise there was ether no data found or the database contains several records with the same client`s name. The configured component looks like this:
If the SQL request returns a single row of data, we can continue. Otherwise we will save a notification in the Workflow log using the “Log to history list” action.
Next, we should load data returned by the SQL script into separate variables. To do that, the “Get Array Item” action of the “HarePoint Activities – Arrays” actions group will be used:
In this step we obtain all necessary data from the SQL database and start generating invoice.
To copy the invoice template we should use the “Copy or Move Documents” action from the “HarePoint Activities – Document Library” activity group.
The link to the document template should be specified in the parameters for this action. The full path to the document should be specified. In our example it is as follows:
The new file should be placed into the document library “Invoices” which we created in the Step 3. It is necessary to specify the full path to the document library. In our example it is as follows:
Set the invoice number field to be used as the data source for the file name:
Next, we should use the “Update Word Document” action (this action is located in the “HarePoint Activities – Office” category) to replace “Content Control” values in the document with the values of the corresponding fields of the new element in the document library.
We select Content Control as the parameter and indicate which document should be updated. Also, we should indicate the data that should be added to the field:
The remaining fields are to be filled in similarly but for the field which should be filled in with data from SQL database we should select “Variable: SQL Address”:
Next, we should add an action to convert the updated document into a PDF file.
To do this, we will use the “Convert Document” action (this action is located in the “HarePoint Activities – Document Conversion” category).
The previously filled-out Invoice is used as the parameter:
Execution of this action will take a while. So, we need to suspend Workflow until the conversion is finished. For that we will use the “Wait Conversion Job” action.
After that we will have two invoice files, and the Word document is to be deleted by using the “Delete Item at URL” action from the “HarePoint Activities – Lists” category. The path to this document should be specified as the parameter:
Now we should add an action to send the generated invoice via email. The “Send E-mail with Document as Attachment” action from the “HarePoint Activities – E-mail” category will be used.
The 'To' address is taken from the new element which was added into the List:
Specify message subject.
And specify the path to the generated PDF invoice.
The workflow is ready. It looks like:
Save the Workflow.
Now we should set the Workflow to be launched automatically when a new list item is created. To do this click the “Workflows” link in the left menu of SharePoint Designer, select your Workflow and double click it. Check the option “Start workflow automatically when an item is created” and click the “Save” button on the ribbon. Save and Publish the Workflow:
Test the Workflow:
Create a new list item, wait a moment, and look at the “Invoices” Document Library. Check your mailbox, the invoice in the PDF format should be there. Check the message subject and make sure that all Invoice fields are filled in properly.