Procedure: Send Order Notifications
- Create a cursor to loop over all the orders placed
- Create an inner cursor to grab and list the order details
- Style details with HTML
- Create another inner cursor to grab additional details (backorder statuses, exceptions, etc)
- Style this information with more HTML
- Create a third cursor to grab all email addresses
- String these into a To: line
- Send the email
If you wanted, you could drown yourself in MSDN's thorough descriptions of FOR XML and PATH mode, but the key is that its intended usage is to allow you to string together a result set into any XML schema you desire. The gold nugget here is that this same functionality can be user to concatenate a result set together into a string along with any other info you choose! Each of my inner cursor loops could now be replaced with a single SELECT query with the FOR XML PATH ('') clause at the end to smoosh everything together into a single string! Here's a simple example I used for building my list of recipient addresses:
SET @To =(
SELECT COALESCE(
STUFF((
SELECT DISTINCT ','+EmailAddress
FROM UserTable
WHERE StoreNumber = @Store
FOR XML PATH ('')
),1,1,''),
'Dropbox@ourcompany.com'))
The SELECT statement at the core of the code takes all the matching email addresses for the current store number, adds a comma to the front of them, and concatenates them together into one string. The STUFF statement that wraps it then removes the first character of the string, which should be a comma. If, however, there were no results returned, and the string doesn't have a first character, the STUFF statement returns NULL. I catch this case by wrapping it in a COALESCE statement, which will return a default address if no matching ones are found (in this case, our agency's default B2B inbox). I used a COALESCE statement rather than ISNULL. For some reason, using ISNULL in this case returns only the first character of "Dropbox@ourcompany.com" if the result set is NULL, rather than the whole address.
As you can see, this opens a lot of possibilities! What used to take a cursor loop and several lines of string concatenations to build an HTML table for an email body can now be replaced with one statement that strings the field and formatting HTML together. If you find this useful, or have yourself employed FOR XML PATH('') in your own work in some interesting ways, leave me a comment!
No comments:
Post a Comment
Thanks for wanting to leave a comment! I'll try to read and respond as soon as I'm able!