<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:copyright="http://blogs.law.harvard.edu/tech/rss" xmlns:image="http://purl.org/rss/1.0/modules/image/">
    <channel>
        <title>புள்ளிவலை</title>
        <link>http://blog.krupashankar.com/pullivalai/Default.aspx</link>
        <description>மூளைக்குத் தீனியில்லாத போழ்துசிறிது மனதுக்கும் ஈயப்படும்.</description>
        <language>ta</language>
        <copyright>சு. க்ருபா ஷங்கர்</copyright>
        <generator>Subtext Version 2.1.2.2</generator>
        <image>
            <title>புள்ளிவலை</title>
            <url>http://blog.krupashankar.com/images/RSS2Image.gif</url>
            <link>http://blog.krupashankar.com/pullivalai/Default.aspx</link>
            <width>77</width>
            <height>60</height>
        </image>
        <item>
            <title>தமிழில் பெயர் வைக்க ஒரு செக் கன்ஸ்ட்ரைண்ட்</title>
            <category>தகவல் தளம்</category>
            <link>http://blog.krupashankar.com/pullivalai/archive/2010/03/14/46.aspx</link>
            <description>&lt;p&gt;தகவல்தளத்தினுள் தவறான தகவல் சேர்ந்துவிடாமல் இருக்க database constraints உதவுகிறது. தகவல் சீர்மைக்கு constraint இன்றியமையாதது. இந்த கன்ஸ்ட்ரைண்டில் பல வகைகள் உள்ளன. உதாரணமாக default value constraint (காலியான தகவல் இருப்பதை அனுமதிக்க/மறுக்க), foreign key constraint (மற்ற டேபிள்களுடன் எந்த  விட தொடர்பும் இல்லாத தகவல்களை நிராகரிக்க), check constraint (நாம் குறிப்பிடும் சில நிபந்தனைகளுக்கு உட்படும் தகவலை மட்டும் அனுமதிக்க) போன்றவை.&lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;`Check constraint கொஞ்சம் flexible ஆனது. நாம் விரும்பும் data validation எல்லாவற்றையும் ஒவ்வொரு fieldக்கும் வைக்கலாம்.&lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;எடுத்துக்காட்டாக, ஒரு தமிழ் வலைப்பதிவு மென்பொருளை உருவாக்குவதாக வைத்துக்கொள்வோம். இந்த மென்பொருளில் ஒரு கண்டிஷன் வைக்கலாம். வலைப்பதிவின் தலைப்பு கண்டிப்பாகத் தமிழில்தான் இருக்கவேண்டும். எதற்கு இப்படி ஒரு வெட்டிவேலை என்று நினைக்கத்தோன்ற்கிறதா? நல்ல கேள்வி. அத்ற்கு விடை இந்தப்பதிவின் கடைசியில் சொல்கிறேன்.&lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;அப்ளிகேஷன் அளவில் இதற்கு ஒரு நிபந்தனையை அமைத்து தகவல் உள்ளீட்டு நிலையிலேயே ஆங்கில எழுத்துக்கள் உள்ள தலைப்பைக் கட்டுப்படுத்திவிடலாம். ASP.NET regular expression validation control ஒன்றே இதற்குப் போதுமானது. அப்ளிகேஷன் சொதப்பினால் கூட, டேட்டாபேசில் தவறான தகவல் இடம்பெற்றுவிடக்கூடாது என்றால் அதற்கு ஒரு check constraint பயன்படுத்தலாம்.&lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;கீழ்க்கண்டவாறு டேபிள் structure இருக்கிறது என்று வைத்துக்கொள்வோம்:&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Table Name&lt;/strong&gt;: TamilPosts&lt;/p&gt;
&lt;table width="400" cellspacing="0" cellpadding="2" border="2"&gt;
    &lt;tbody&gt;
        &lt;tr&gt;
            &lt;td width="200" valign="top"&gt;&lt;strong&gt;Column Name&lt;/strong&gt;&lt;/td&gt;
            &lt;td width="200" valign="top"&gt;&lt;strong&gt;Data Type&lt;/strong&gt;&lt;/td&gt;
        &lt;/tr&gt;
        &lt;tr&gt;
            &lt;td width="200" valign="top"&gt;blogid&lt;/td&gt;
            &lt;td width="200" valign="top"&gt;int&lt;/td&gt;
        &lt;/tr&gt;
        &lt;tr&gt;
            &lt;td width="200" valign="top"&gt;PostTitle&lt;/td&gt;
            &lt;td width="200" valign="top"&gt;nvarchar(1000)&lt;/td&gt;
        &lt;/tr&gt;
        &lt;tr&gt;
            &lt;td width="200" valign="top"&gt;PostContent&lt;/td&gt;
            &lt;td width="200" valign="top"&gt;nvarchar(4000)&lt;/td&gt;
        &lt;/tr&gt;
    &lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;இந்த டேபிளுக்கு PostTitle fieldல் ஆங்கில எழுத்துக்கள் இடம்பெறக்கூடாது.&lt;/p&gt;
&lt;p&gt;ஆங்கில எழுத்து, தமிழ் எழுத்து என்பதை எல்லாம் கண்டறிய SQL Serverல் ஃபங்க்‌ஷன் கிடையாது. எனவே, முதலில் இதை எழுதலாம். இப்படி:&lt;/p&gt;
&lt;div id="codeSnippetWrapper"&gt;
&lt;pre class="csharpcode" id="codeSnippet"&gt;&lt;span class="kwrd"&gt;CREATE&lt;/span&gt; &lt;span class="kwrd"&gt;FUNCTION&lt;/span&gt; [dbo].[HasEnglishLetters]&lt;br /&gt;(&lt;br /&gt;   &lt;span class="rem"&gt;-- Add the parameters for the function here&lt;/span&gt;&lt;br /&gt;    @PostTitle nvarchar(1000)&lt;br /&gt;)&lt;br /&gt;&lt;span class="kwrd"&gt;RETURNS&lt;/span&gt; &lt;span class="kwrd"&gt;bit&lt;/span&gt;&lt;br /&gt;&lt;span class="kwrd"&gt;AS&lt;/span&gt;&lt;br /&gt;&lt;span class="kwrd"&gt;BEGIN&lt;/span&gt;&lt;br /&gt;    &lt;span class="kwrd"&gt;Declare&lt;/span&gt; @HasEnglishContentbit&lt;br /&gt;    &lt;span class="kwrd"&gt;select&lt;/span&gt; @HasEnglishContent =&lt;span class="kwrd"&gt;case&lt;/span&gt; &lt;span class="kwrd"&gt;when&lt;/span&gt; @PostTitle &lt;span class="kwrd"&gt;like&lt;/span&gt; &lt;span class="str"&gt;'%[a-z]%'&lt;/span&gt; &lt;span class="kwrd"&gt;then&lt;/span&gt; 1else 0end&lt;br /&gt;    &lt;span class="rem"&gt;-- Return the result of the function&lt;/span&gt;&lt;br /&gt;    &lt;span class="kwrd"&gt;RETURN&lt;/span&gt; @HasEnglishContent&lt;br /&gt;&lt;br /&gt;END&lt;/pre&gt;
&lt;br /&gt;
&lt;/div&gt;
&lt;p&gt;   &lt;br /&gt;
&lt;/p&gt;
&lt;p&gt;மேலே உள்ள ஃபங்க்‌ஷன் ஒரு எழுத்துச்சரத்தை எடுத்துக்கொண்டு, அதில் ஆங்கில எழுத்துக்கள் கலந்து இருக்கிறதா இல்லையா என்பதைத் தெரிவிக்கும். ஆங்கில எழுத்துக்கள் இருக்கிறது என்றால் 1 என்றும், இல்லை என்றால் 0 என்றும் இந்த ஃபங்க்‌ஷன் தெரிவிக்கும்.&lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;இந்த ஃபங்க்‌ஷனை இப்பொழுது ஒரு check constraint-ஆக நம்முடைய டேபிளில் இணைக்கவேண்டும். அதற்கு கீழ்க்கண்ட SQL DDLஐப் பயன்படுத்தலாம்;:&lt;/p&gt;
&lt;div id="codeSnippetWrapper"&gt;
&lt;pre class="csharpcode" id="codeSnippet"&gt;&lt;span class="kwrd"&gt;ALTER&lt;/span&gt; &lt;span class="kwrd"&gt;TABLE&lt;/span&gt; [dbo].[TamilPosts]  &lt;span class="kwrd"&gt;WITH&lt;/span&gt; &lt;span class="kwrd"&gt;CHECK&lt;/span&gt; &lt;br /&gt;&lt;span class="kwrd"&gt;ADD&lt;/span&gt;  &lt;span class="kwrd"&gt;CONSTRAINT&lt;/span&gt; [CK_TamilPostTitle] &lt;span class="kwrd"&gt;CHECK&lt;/span&gt; &lt;br /&gt; (([dbo].[HasEnglishLetters]([PostTitle])=(0)))&lt;br /&gt;&lt;span class="kwrd"&gt;GO&lt;/span&gt;&lt;br /&gt;&lt;span class="kwrd"&gt;ALTER&lt;/span&gt; &lt;span class="kwrd"&gt;TABLE&lt;/span&gt; [dbo].[TamilPosts] &lt;span class="kwrd"&gt;CHECK&lt;/span&gt; &lt;span class="kwrd"&gt;CONSTRAINT&lt;/span&gt; [CK_TamilPostTitle]&lt;/pre&gt;
&lt;br /&gt;
&lt;/div&gt;
&lt;p&gt;அல்லது, நேராக டேபிளின் டிசைன் வ்யூவுக்குச் சென்று, ஏதாவது ஒரு காலத்தின் மேல் வலது க்ளிக் செய்து Check Constraints… மெனுவைத் தேர்ந்தெடுக்கவேண்டும். பிறகு வரும் Check Constraints சாளரத்தில், Expression ப்ராப்பர்டியில் ([dbo].[HasEnglishLetters]([PostTitle])=(0)) என்று கொடுக்கவேண்டும். இதற்கான காட்சித்திரை:&lt;/p&gt;
&lt;p&gt;&lt;img width="639" height="617" title="New check constraint to reject data with english letters" alt="New check constraint to reject data with english letters" src="/images/blog_krupashankar_com/pullivalai/4/o_checkconstraint_tamilletter.jpg" /&gt; &lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;இனிமேல் ஆங்கில எழுத்துள்ள தலைப்பை உள்ளிட்டால், “தூ தூ” என்று கீழ்க்கண்டவாறு துப்பும். முயற்சிப்போமா?&lt;/p&gt;
&lt;div id="codeSnippetWrapper"&gt;
&lt;pre class="csharpcode" id="codeSnippet"&gt;insert &lt;span class="kwrd"&gt;into&lt;/span&gt; tamilposts &lt;span class="kwrd"&gt;values&lt;/span&gt;(1, &lt;span class="str"&gt;'test'&lt;/span&gt;, &lt;span class="str"&gt;'test content'&lt;/span&gt;)&lt;/pre&gt;
&lt;br /&gt;
&lt;/div&gt;
&lt;p&gt;&lt;font color="#ff0000"&gt;Msg 547, Level 16, State 0, Line 1      &lt;br /&gt;
The INSERT statement conflicted with the CHECK constraint "CK_TamilPosts". The conflict occurred in database "pullivalai", table "dbo.TamilPosts", column 'PostTitle'.       &lt;br /&gt;
&lt;/font&gt;The statement has been terminated.&lt;/p&gt;
&lt;p&gt;இந்த பிழைச்செய்தியின் அடிப்படையில் முன்முகப்பு நிரலிலும் பயனர்ச்சொல்லில் பிழையை அறிவிக்கலாம்.&lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;தமிழில்தான் வலைப்பதிவின் தலைப்பு இருக்கவேண்டும் என்பதாக எதற்கு ஒரு மென்பொருள் இருக்கவேண்டும் என்று கேட்பவர்களுக்கு ... அது. .. வந்துங்க .. பிற்காலத்தில் இந்த மென்பொருளில் இட்ட பதிவைப் பார்த்து ஒரு படமெடுத்தால், அந்த திரைப்படத்திற்குத் தமிழில் பெயர் வைப்பது சுலபம், இல்லையா?&lt;/p&gt;
&lt;p&gt; &lt;/p&gt;
&lt;p&gt;ஆங்கிலச்சொற்கலைத் தமிழில் எழுதினால் அதை இந்த check constraint வைத்து எப்படி தடுக்க முடியும் என்று நினைக்கத்தோன்ற்கிறதா? நல்ல கேள்வி. அதற்கு விடை இந்தப்பதிவின்.... ச்சே! வேண்டாம். என்னுடைய மொக்கை எனக்கே சகிக்கவில்லை. இத்துடன் உங்களுக்கு விடுதலை.&lt;/p&gt;&lt;img src="http://blog.krupashankar.com/pullivalai/aggbug/46.aspx" width="1" height="1" /&gt;</description>
            <dc:creator>சு. க்ருபா ஷங்கர்</dc:creator>
            <guid>http://blog.krupashankar.com/pullivalai/archive/2010/03/14/46.aspx</guid>
            <pubDate>Sun, 14 Mar 2010 00:36:03 GMT</pubDate>
            <wfw:comment>http://blog.krupashankar.com/pullivalai/comments/46.aspx</wfw:comment>
            <comments>http://blog.krupashankar.com/pullivalai/archive/2010/03/14/46.aspx#feedback</comments>
            <slash:comments>1</slash:comments>
            <wfw:commentRss>http://blog.krupashankar.com/pullivalai/comments/commentRss/46.aspx</wfw:commentRss>
        </item>
    </channel>
</rss>