This example requires ActivMail 1.3 or greater
<!--- we are defining a query here with 3 columns num,email,direction ---> <cfset q = QueryNew("num,email,direction")> <!--- row 1 num=1, email=[email protected], direction=North ---> <cfset r = QueryAddRow(q)> <cfset QuerySetCell(q, "num", 1, r)> <cfset QuerySetCell(q, "email", "[email protected]", r)> <cfset QuerySetCell(q, "direction", "North", r)> <!--- row 2 num=2, email=[email protected], direction=South ---> <cfset r = QueryAddRow(q)> <cfset QuerySetCell(q, "num", 2, r)> <cfset QuerySetCell(q, "email", "[email protected]", r)> <cfset QuerySetCell(q, "direction", "South", r)> <!--- lets see what the query looks like ---> <cfdump var="#q#"> <!--- we could have also done something like this ---> <!--- <cfquery datasource="ds" name="q"> SELECT Num, Email, Direction FROM table </cfquery> ---> <!--- now we have a query defined lets loop through and generate personalized content ---> <!--- the content is stored in an array that corresponds to the query row numbers ---> <cfset contentArray = ArrayNew(1)> <cfoutput query="q"> <cfsavecontent variable="personalContent"> <cfif q.direction IS "North"> <p><b>North</b> is the better direction to go here. I'm glad you picked north.</p> <cfelseif q.direction IS "South"> <p><b>South</b> is much better than North.</p> </cfif> Your number is #q.num# </cfsavecontent> <cfset contentArray[q.currentRow] = personalContent> </cfoutput> <cfset QueryAddColumn(q, "content", contentArray)> <!--- now lets see what the query looks like ---> <br> <cfdump var="#q#"> <cf_mail query="q" tokens="1" sendmode="query" to="email" from="[email protected]" subject="^direction^ is the way to go!" tokenchar="^" type="html"> ^content^ <p> Email: ^email^<br> Num: ^num^<br> </p> personalizedMessage.cfm </cf_mail>