<?xml version='1.0' encoding='UTF-8'?><?xml-stylesheet href="http://www.blogger.com/styles/atom.css" type="text/css"?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:georss='http://www.georss.org/georss' xmlns:gd='http://schemas.google.com/g/2005' xmlns:thr='http://purl.org/syndication/thread/1.0'><id>tag:blogger.com,1999:blog-4341662299710595595</id><updated>2011-04-21T12:38:03.238-07:00</updated><category term='.net'/><category term='software'/><title type='text'>Meet Developer Chad</title><subtitle type='html'></subtitle><link rel='http://schemas.google.com/g/2005#feed' type='application/atom+xml' href='http://devchad.blogspot.com/feeds/posts/default'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/4341662299710595595/posts/default?max-results=100'/><link rel='alternate' type='text/html' href='http://devchad.blogspot.com/'/><link rel='hub' href='http://pubsubhubbub.appspot.com/'/><author><name>Chad</name><uri>http://www.blogger.com/profile/13985477622300730118</uri><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='22' height='32' src='http://bp2.blogger.com/_hZXXGq35RHM/SBo0rQJZBSI/AAAAAAAAAAQ/-ADVgscD_lI/S220/ChadsMug.jpg'/></author><generator version='7.00' uri='http://www.blogger.com'>Blogger</generator><openSearch:totalResults>1</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>100</openSearch:itemsPerPage><entry><id>tag:blogger.com,1999:blog-4341662299710595595.post-4006107858803147894</id><published>2008-05-01T14:30:00.000-07:00</published><updated>2008-05-01T18:09:49.908-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='.net'/><category scheme='http://www.blogger.com/atom/ns#' term='software'/><title type='text'>Software Project: Mona VDP</title><content type='html'>VDP stands for Variable Data Printing. VDP is at it's simplest a form of 'mail merge' which is typically used to allow a printed piece to be personalized. The client needed to allow personalized thank you letters / receipts to be printed.&lt;br /&gt;&lt;br /&gt;&lt;div&gt;There were a handful of applications out there for this purpose but very few of them extract the data for you. This non-profit needed not only to extract information from their donor database but also to update the original records to indicate that an acknowledgement had been printed. &lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;img id="BLOGGER_PHOTO_ID_5195580714914481538" style="DISPLAY: block; MARGIN: 0px auto 10px; CURSOR: hand; TEXT-ALIGN: center" alt="" src="http://bp3.blogger.com/_hZXXGq35RHM/SBppIgJZBYI/AAAAAAAAAA8/1XCY_IU7vfk/s320/Image-0010.gif" border="0" /&gt;&lt;br /&gt;&lt;div&gt;Mona VDP was designed to allow jobs to obtain data as well as update data from any Odbc datasource using SQL. In addition, the select datasource does not even have to be the same as the update datasource. Distributed transactions are used to ensure atomicity.&lt;br /&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;/div&gt;&lt;img id="BLOGGER_PHOTO_ID_5195580946842715538" style="DISPLAY: block; MARGIN: 0px auto 10px; CURSOR: hand; TEXT-ALIGN: center" alt="" src="http://bp1.blogger.com/_hZXXGq35RHM/SBppWAJZBZI/AAAAAAAAABE/fgtvc4wSx1g/s320/Image-0009.gif" border="0" /&gt;&lt;br /&gt;&lt;div&gt;&lt;a href="http://bp0.blogger.com/_hZXXGq35RHM/SBpgfwJZBVI/AAAAAAAAAAk/R0HXH_2PtHQ/s1600-h/Image-0009.gif"&gt;&lt;/a&gt;Another design goal was to allow receipts to contain variable rich text letters. Crystal Reports was chosen because of its support for rich text database fields. A letters module was designed for Mona VDP to allow custom letters with merge fields to be created. &lt;/div&gt;&lt;div&gt;&lt;/div&gt;&lt;div&gt;&lt;/div&gt;&lt;br /&gt;&lt;div&gt;The letters also needed to have a personal signature block which could vary for each letter. These are stored in the VDP database and eventually make their way into a dataset to be displayed in Crystal Reports.&lt;/div&gt;&lt;div&gt;&lt;/div&gt;&lt;br /&gt;&lt;img id="BLOGGER_PHOTO_ID_5195580281122784626" style="DISPLAY: block; MARGIN: 0px auto 10px; CURSOR: hand; TEXT-ALIGN: center" alt="" src="http://bp2.blogger.com/_hZXXGq35RHM/SBpovQJZBXI/AAAAAAAAAA0/6aukv5W0XEM/s400/Image-0006.gif" border="0" /&gt;&lt;br /&gt;&lt;div&gt;Crystal Reports also has a great .NET API which allows ADO.NET datasets to be passed to the report runtime for previewing or printing the report. Crystal Reports Designer is needed to create the layout for the new print job.&lt;/div&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4341662299710595595-4006107858803147894?l=devchad.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://devchad.blogspot.com/feeds/4006107858803147894/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://www.blogger.com/comment.g?blogID=4341662299710595595&amp;postID=4006107858803147894' title='2 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/4341662299710595595/posts/default/4006107858803147894'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/4341662299710595595/posts/default/4006107858803147894'/><link rel='alternate' type='text/html' href='http://devchad.blogspot.com/2008/05/software-project-mona-vdp.html' title='Software Project: Mona VDP'/><author><name>Chad</name><uri>http://www.blogger.com/profile/13985477622300730118</uri><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='22' height='32' src='http://bp2.blogger.com/_hZXXGq35RHM/SBo0rQJZBSI/AAAAAAAAAAQ/-ADVgscD_lI/S220/ChadsMug.jpg'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://bp3.blogger.com/_hZXXGq35RHM/SBppIgJZBYI/AAAAAAAAAA8/1XCY_IU7vfk/s72-c/Image-0010.gif' height='72' width='72'/><thr:total>2</thr:total></entry></feed>
