<?xml version="1.0" encoding="UTF-8"?>
<!--Generated by Squarespace Site Server v5.8.4 (http://www.squarespace.com/) on Sun, 06 Dec 2009 01:01:05 GMT--><rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" xmlns:dc="http://purl.org/dc/elements/1.1/" version="2.0"><channel><title>Sql Server Posts</title><link>http://pinyination.squarespace.com/sql-server-posts/</link><description></description><lastBuildDate>Thu, 18 Dec 2008 22:17:02 +0000</lastBuildDate><copyright></copyright><language>en-US</language><generator>Squarespace Site Server v5.8.4 (http://www.squarespace.com/)</generator><item><title>Check Digit Routine using Mod 10</title><dc:creator>Alyssa Biederman</dc:creator><pubDate>Tue, 28 Oct 2008 17:33:28 +0000</pubDate><link>http://pinyination.squarespace.com/sql-server-posts/2008/10/28/check-digit-routine-using-mod-10.html</link><guid isPermaLink="false">269409:2925355:2478420</guid><description><![CDATA[<html xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:w="urn:schemas-microsoft-com:office:word"
xmlns="http://www.w3.org/TR/REC-html40">

<head>
<meta http-equiv=Content-Type content="text/html; charset=us-ascii">
<meta name=ProgId content=Word.Document>
<meta name=Generator content="Microsoft Word 11">
<meta name=Originator content="Microsoft Word 11">
<link rel=File-List href="13657DC0_files/filelist.xml">
<!--[if gte mso 9]><xml>
 <o:DocumentProperties>
  <o:Author>arbiederman</o:Author>
  <o:Template>Normal</o:Template>
  <o:Revision>1</o:Revision>
  <o:TotalTime>35</o:TotalTime>
  <o:Created>2008-10-28T17:03:00Z</o:Created>
  <o:Pages>1</o:Pages>
  <o:Words>411</o:Words>
  <o:Characters>2345</o:Characters>
  <o:Company>HMB</o:Company>
  <o:Lines>19</o:Lines>
  <o:Paragraphs>5</o:Paragraphs>
  <o:CharactersWithSpaces>2751</o:CharactersWithSpaces>
  <o:Version>11.9999</o:Version>
 </o:DocumentProperties>
</xml><![endif]--><!--[if gte mso 9]><xml>
 <w:WordDocument>
  <w:SpellingState>Clean</w:SpellingState>
  <w:GrammarState>Clean</w:GrammarState>
  <w:PunctuationKerning/>
  <w:ValidateAgainstSchemas/>
  <w:SaveIfXMLInvalid>false</w:SaveIfXMLInvalid>
  <w:IgnoreMixedContent>false</w:IgnoreMixedContent>
  <w:AlwaysShowPlaceholderText>false</w:AlwaysShowPlaceholderText>
  <w:Compatibility>
   <w:BreakWrappedTables/>
   <w:SnapToGridInCell/>
   <w:WrapTextWithPunct/>
   <w:UseAsianBreakRules/>
   <w:DontGrowAutofit/>
  </w:Compatibility>
  <w:BrowserLevel>MicrosoftInternetExplorer4</w:BrowserLevel>
 </w:WordDocument>
</xml><![endif]--><!--[if gte mso 9]><xml>
 <w:LatentStyles DefLockedState="false" LatentStyleCount="156">
 </w:LatentStyles>
</xml><![endif]-->
<style>
<!--
 /* Font Definitions */
 @font-face
	{font-family:Garamond;
	panose-1:2 2 4 4 3 3 1 1 8 3;
	mso-font-charset:0;
	mso-generic-font-family:roman;
	mso-font-pitch:variable;
	mso-font-signature:647 0 0 0 159 0;}
 /* Style Definitions */
 p.MsoNormal, li.MsoNormal, div.MsoNormal
	{mso-style-parent:"";
	margin:0in;
	margin-bottom:.0001pt;
	mso-pagination:widow-orphan;
	font-size:12.0pt;
	font-family:"Times New Roman";
	mso-fareast-font-family:"Times New Roman";}
@page Section1
	{size:8.5in 11.0in;
	margin:.5in .5in .5in .5in;
	mso-header-margin:.5in;
	mso-footer-margin:.5in;
	mso-paper-source:0;}
div.Section1
	{page:Section1;}
-->
</style>
<!--[if gte mso 10]>
<style>
 /* Style Definitions */
 table.MsoNormalTable
	{mso-style-name:"Table Normal";
	mso-tstyle-rowband-size:0;
	mso-tstyle-colband-size:0;
	mso-style-noshow:yes;
	mso-style-parent:"";
	mso-padding-alt:0in 5.4pt 0in 5.4pt;
	mso-para-margin:0in;
	mso-para-margin-bottom:.0001pt;
	mso-pagination:widow-orphan;
	font-size:10.0pt;
	font-family:"Times New Roman";
	mso-ansi-language:#0400;
	mso-fareast-language:#0400;
	mso-bidi-language:#0400;}
</style>
<![endif]-->
</head>

<body lang=EN-US style='tab-interval:.5in'>

<div class=Section1>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>The following is a handy function that I wrote in SQL Server
to return a check <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>digit for a string of numbers (in my case, a scanline). It
uses the Luhn <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>Algorithm &#8211; also referred to as modulus 10. Starting
with a string of <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>numbers, the algorithm works as follows:<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>178009067 (this is our number string)<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>Now, starting with the first digit on the RIGHT, take the sum
of all digits, <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>doubling every other digit and adding them together. The
first digit we should <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>double is the second from the right. We would get:<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>7 + (1 + 2) + 0 + (1 + 8) + 0 + 0 + 8 + (1 + 4) + 1 = 33<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>Our check digit will be whatever we need to add to this total
to make it <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>divisible by 10. In this case our check digit is 7.<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>Here is a function that will automatically calculate a check
digit when it is <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:11.0pt;font-family:Garamond;mso-bidi-font-family:"Courier New";
mso-no-proof:yes'>passed a string of numbers.<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>set</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> <span
style='color:blue'>ANSI_NULLS</span> <span style='color:blue'>ON<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>set</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> <span
style='color:blue'>QUOTED_IDENTIFIER</span> <span style='color:blue'>ON<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'>go<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>ALTER</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> <span
style='color:blue'>FUNCTION</span> [dbo]<span style='color:gray'>.</span>[fnCalcCheckDigit]
<span style='color:gray'>(</span>@sOrig <span style='color:blue'>VARCHAR</span><span
style='color:gray'>(</span>34<span style='color:gray'>))<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:gray;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
@sOrig represents the string you are sending to the function. <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
If you are calculating a check digit for an OCR scanline for <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
example, @sOrig should contain the full scanline. Make sure <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
your varchar is big enough to hold the string, but not <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
inefficiently large<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>RETURNS</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> <span
style='color:blue'>VARCHAR</span><span style='color:gray'>(</span>1<span
style='color:gray'>)<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:gray;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>AS<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>BEGIN<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>DECLARE</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @i <span
style='color:blue'>INT</span><span style='color:gray'>,</span> @j <span
style='color:blue'>INT</span><span style='color:gray'>,</span> @total <span
style='color:blue'>INT</span><span style='color:gray'>,</span> @finish <span
style='color:blue'>INT</span><span style='color:gray'>,</span> @result <span
style='color:blue'>BIT</span><span style='color:gray'>,</span> @testMsg <span
style='color:blue'>VARCHAR</span><span style='color:gray'>(</span>50<span
style='color:gray'>),</span> @double <span style='color:blue'>BIT<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
@j will temporarily store the value of the string digit to be<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
added into the running total after each iteration<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
@finish will store the scanline and the check digit<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
@total will hold the running total and will be <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
incremented by @j<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
@double is a boolean variable that will represent if a <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
digit is odd or even (since every other digit must be <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
doubled and added to the running total.<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>SET</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @finish <span
style='color:gray'>=</span> 0<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>SET</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @total <span
style='color:gray'>=</span> 0<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>SET</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @sOrig <span
style='color:gray'>=</span><span style='mso-tab-count:1'>&nbsp; </span><span
style='color:fuchsia'>LTRIM</span><span style='color:gray'>(</span>@sOrig<span
style='color:gray'>)<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>SET</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @sOrig <span
style='color:gray'>=</span><span style='mso-tab-count:1'>&nbsp; </span><span
style='color:fuchsia'>RTRIM</span><span style='color:gray'>(</span>@sOrig<span
style='color:gray'>)<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>SET</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @i <span
style='color:gray'>=</span><span style='mso-tab-count:1'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:fuchsia'>LEN</span><span style='color:gray'>(</span>@sOrig<span
style='color:gray'>)<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:gray;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
Always start with an odd digit - our first digit to be <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
doubled will be the second from the right<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>SET</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @double <span
style='color:gray'>=</span> 0<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>WHILE</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @i <span
style='color:gray'>&gt;</span> 0<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>BEGIN<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:1'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SELECT</span> @j<span style='color:gray'>=(</span><span
style='color:fuchsia'>ASCII</span><span style='color:gray'>(</span><span
style='color:fuchsia'>SUBSTRING</span><span style='color:gray'>(</span>@sOrig<span
style='color:gray'>,</span> @i<span style='color:gray'>,</span> 1<span
style='color:gray'>))-</span>48<span style='color:gray'>)<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>IF</span> @double <span style='color:gray'>=</span> 1<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>BEGIN<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:3'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SET</span> @j <span style='color:gray'>=</span> @j <span
style='color:gray'>*</span> 2<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
If the digit * 2 is a two digit number <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
(for example 8 * 2 = 16), then we need to add 1 + 6. <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
We can use 16 - 9, because any digit doubled minus <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
9 will equal the sum of the two digits that make <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
up the number.<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:3'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>IF</span> @j <span style='color:gray'>&gt;</span> 9<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:3'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>BEGIN<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:4'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SET</span> @j <span style='color:gray'>=</span> @j <span
style='color:gray'>-</span> 9<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:3'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>END<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:3'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SET</span> @double <span style='color:gray'>=</span> 0<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>END<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>ELSE<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>BEGIN<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
Set this flag so we know to double the next digit<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:3'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SET</span> @double <span style='color:gray'>=</span> 1<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>END<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SET</span> @total <span style='color:gray'>=</span> @total <span
style='color:gray'>+</span> @j<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:2'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SET</span> @i <span style='color:gray'>=</span> @i <span
style='color:gray'>-</span> 1<span style='mso-tab-count:1'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>END<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
Take the modulus 10 - if it is equal to zero, <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
then check digit is zero, otherwise, <o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'>--
store the check digit in @finish<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:green;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>IF</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> @total <span
style='color:gray'>%</span> 10 <span style='color:gray'>=</span> 0<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:1'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SELECT</span> @finish <span style='color:gray'>=</span> 0<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>ELSE<o:p></o:p></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'><span
style='mso-tab-count:1'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
style='color:blue'>SELECT</span> @finish <span style='color:gray'>=</span> 10 <span
style='color:gray'>-</span> <span style='color:gray'>(</span>@total <span
style='color:gray'>%</span> 10<span style='color:gray'>)<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:blue;mso-no-proof:yes'>RETURN</span><span
style='font-size:8.0pt;font-family:"Courier New";mso-no-proof:yes'> <span
style='color:gray'>(</span>@finish<span style='color:gray'>)<o:p></o:p></span></span></p>

<p class=MsoNormal style='mso-layout-grid-align:none;text-autospace:none'><span
style='font-size:8.0pt;font-family:"Courier New";color:gray;mso-no-proof:yes'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='font-size:8.0pt;font-family:"Courier New";
color:blue;mso-no-proof:yes'>END</span><span style='font-size:8.0pt'><o:p></o:p></span></p>

</div>

</body>

</html>
]]></description><wfw:commentRss>http://pinyination.squarespace.com/sql-server-posts/rss-comments-entry-2478420.xml</wfw:commentRss></item></channel></rss>