This is a valid Atom 1.0 feed.
This feed is valid, but interoperability with the widest range of feed readers could be improved by implementing the following recommendations.
... r.com/styles/atom.css" type="text/css"?><feed xmlns='http://www.w3.org/2 ...
^
... r.com/styles/atom.css" type="text/css"?><feed xmlns='http://www.w3.org/2 ...
^
... Programms</title><subtitle type='html'></subtitle><link rel='http://sch ...
^
... eds/3691376985285892436/posts/default'/><link rel='alternate' type='text ...
^
line 1, column 0: (35 occurrences) [help]
<?xml version='1.0' encoding='UTF-8'?><?xml-stylesheet href="http://www.blog ...
line 5, column 0: (70 occurrences) [help]
<img border="0" height="241" src="https://blogge ...
line 79, column 0: (5 occurrences) [help]
<h5 class="uiStreamMessage userContentWrapper" data-ft="{& ...
<a ajaxify="https://www.facebook.com/photo.php?fbid=626772577353395& ...
line 933, column 0: (7 occurrences) [help]
<div class="post-body entry-content" id="post-body-3435056 ...
line 937, column 0: (13 occurrences) [help]
<span style="font-family: 'Courier New', Courier, monospace; ...
<?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:blogger='http://schemas.google.com/blogger/2008' 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-3691376985285892436</id><updated>2024-11-05T18:47:12.199-08:00</updated><title type='text'>Tamil Software Programms</title><subtitle type='html'></subtitle><link rel='http://schemas.google.com/g/2005#feed' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/posts/default'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/'/><link rel='hub' href='http://pubsubhubbub.appspot.com/'/><link rel='next' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default?start-index=26&max-results=25'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><generator version='7.00' uri='http://www.blogger.com'>Blogger</generator><openSearch:totalResults>45</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>25</openSearch:itemsPerPage><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-8932859467994801689</id><published>2013-11-07T19:59:00.001-08:00</published><updated>2013-11-07T19:59:06.050-08:00</updated><title type='text'>விண்டோஸ் அட்மின் பாஸ்வேர்டை மாற்றி அமைக்க</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<br />
<br />
<div class="separator" style="background-color: white; clear: left; color: #555555; float: left; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; margin-bottom: 1em; margin-right: 1em; text-align: center;">
<img border="0" height="241" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjv7QSBfnS1-9-3gxjLlYfpysdtBnx2JiMwj86E9mpl9tt2rOkkC_vtt0G1kKS9jJGUEGUkyIam6c1KNt4qoo-o4N5qW91YPH4PwYYZjthIlohEWz3KYuszpu5ynGBwsZKeGl3zsBR0MRYl/s320/windows_xp_password.jpg" style="background-color: transparent; background-position: initial initial; background-repeat: initial initial; border: none; padding: 0px;" width="320" /></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;">ஆப்லைன் என்.டி. பாஸ்வேர்ட் - ரெஜிஸ்ட்ரி எடிட்டர் (Offline NT Password &amp; Registry Editor ) என்னும் டூலைப் பயன்படுத்தி, கம்ப்யூட்டர் சிஸ்டம் ஒன்றின், அட்மினிஸ்ட்ரேட்டர் பாஸ்வேர்டினை மாற்றி அமைக்கலாம்.&nbsp;</span></span></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;"><br /></span></span></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;">இது ஓப்பன் சோர்ஸ் எனப்படும் திறவூற்று வகையில் அமைக்கப்பட்ட புரோகிராம் என்பதால், இணையத்தில் இலவசமாகவே கிடைக்கிறது. இது பழைய பாஸ்வேர்டினை முழுமையாக அழிக்கிறது.&nbsp;</span></span></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;"><br /></span></span></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;">எனவே, விண்டோஸ் சிஸ்டம் செல்ல வேண்டியதில்லை. இது எந்தப் பிரச்னையும் இன்றி, விண்டோஸ் எக்ஸ்.பி., விஸ்டா மற்றும் விண்டோஸ் 7 சிஸ்டங்களில் செயல்படுகிறது.&nbsp;</span></span></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;"><br /></span></span></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;">இவற்றின் 64 பிட் பதிப்புகளிலும் செயல்படுகிறது. இதற்கு&nbsp;</span><a href="http://pogostick.net/~pnh/ntpasswd/" style="border: 0px none; color: #3e9599; line-height: 19px; margin: 0px; outline: none; padding: 0px; text-decoration: none !important;">http://pogostick.net/~pnh/ntpasswd/</a><span style="line-height: 19px;">என்ற முகவரியில் உள்ள இணையதளம் செல்லவும்.&nbsp;</span></span></div>
<div style="background-color: white; color: #555555; font-family: Georgia, Helvetica, Arial, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: Arial, Helvetica, sans-serif;"><span style="line-height: 19px;"><br /></span></span></div>
<div style="text-align: justify;">
1. முதலில் இந்த இணைய தளம் சென்று, ”How to get it?” பிரிவில், Password reset CD/USB bootdisk: Instructions image என்பதனைக் கண்டறிந்து கிளிக் செய்திடவும். மீண்டும் கீழாகச் சென்று cd110511.zip என்ற பைலைத் தரவிறக்கம் செய்திடவும். இது ஏறத்தாழ 3 எம்.பி. அளவுள்ள பைலாகும்.&nbsp;</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
2. இந்த ஸிப் பைலில் இருந்து, ஐ.எஸ்.ஓ. பைலை எக்ஸ்ட்ராக்ட் செய்திடவும். இந்த பைலை, டிஸ்க் ஒன்றில் பதியவும்.&nbsp;</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
3. அடுத்து, இந்த சிடியினைப் பயன்படுத்தி, உங்கள் கம்ப்யூட்டரை இயக்கவும்.&nbsp;</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
4. பூட் கட்டளைப் புள்ளி தோன்றுகையில், எண்டர் அழுத்தவும். புரோகிராம் லோட் ஆகும் வரையில் காத்திருக்கவும்.&nbsp;</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
5. உங்கள் கம்ப்யூட்டரின் ஹார்ட் ட்ரைவின் அனைத்து பகுதிகளையும் நீங்கள் இங்கு காணலாம். இங்கு, விண்டோஸ் லோட் ஆகி உள்ள ஹார்ட் ட்ரைவின் பகுதியினைத் தேர்ந்தெடுக்கவும். பொதுவாக, மாறா நிலையில், இதுவே முதலாவதாக இருக்கும். இதில் எண்டர் அழுத்தவும்.&nbsp;</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
6. விண்டோஸ் ரெஜிஸ்ட்ரி உள்ள இடத்தின் சரியான இடம் பெறவும். மாறா நிலையில், இது Windows/System32/config என்ற பிரிவில் இருக்கும். மீண்டும் எண்டர் அழுத்தவும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
7. அடுத்து, Password reset [sam system security] என்ற ஆப்ஷனைத் தேர்ந்தெடுக்கவும். எண்டர் அழுத்தவும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
8. பாஸ்வேர்ட் ரீசெட் செய்வதற்கான யூசர் நேம் டைப் செய்திடவும். மீண்டும் எண்டர் தட்டவும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
9. இங்கு யூசர் பாஸ்வேர்டினை நீக்கிட, 1 என்ற ஆப்ஷனைத் தேர்ந்தெடுக்கவும். எண்டர் அழுத்தவும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
10. மேலே காட்டப்பட்டுள்ள அனைத்தையும் எந்த தவறும் இல்லாமல் மேற்கொண்டால், ஒரு உறுதி செய்வதற்கான மெசேஜ் ஒன்று காட்டப்படும். மீண்டும் இப்போது ! யை டைப் செய்து, எடிட்டிங் பணியிலிருந்து வெளியேற எண்டர் தட்டவும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
11. அடுத்து q அழுத்தி புரோகிராமில் இருந்து வெளியேற எண்டர் அழுத்தவும்.&nbsp;</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
12. அடுத்து y என அழுத்தி, அனைத்து மாற்றங்களையும் நிரந்தரமாக வைத்துக் கொள்ள உறுதி செய்திடவும். எண்டர் அழுத்தவும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
13. மீண்டும் புரோகிராம் செல்ல விருப்பம் இல்லை என்பதனைத் தெரிவிக்க, எண்டர் அழுத்தவும்.</div>
<div style="text-align: justify;">
</div>
<span style="background-color: white; color: #555555; font-family: Arial, Helvetica, sans-serif; font-size: 13px; line-height: 18px;"><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span><span style="line-height: 19px;"></span></span><br />
<div style="text-align: justify;">
14. இனி, டிஸ்க்கினை நீக்கி, கம்ப்யூட்டரை ரீஸ்டார்ட் செய்திடவும். இனி, பாஸ்வேர்ட் எதுவும் தராமல், உங்களால், லாக் இன் செய்திட முடியும்.</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/8932859467994801689/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/11/blog-post.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/8932859467994801689'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/8932859467994801689'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/11/blog-post.html' title='விண்டோஸ் அட்மின் பாஸ்வேர்டை மாற்றி அமைக்க'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjv7QSBfnS1-9-3gxjLlYfpysdtBnx2JiMwj86E9mpl9tt2rOkkC_vtt0G1kKS9jJGUEGUkyIam6c1KNt4qoo-o4N5qW91YPH4PwYYZjthIlohEWz3KYuszpu5ynGBwsZKeGl3zsBR0MRYl/s72-c/windows_xp_password.jpg" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-7406934568444607046</id><published>2013-09-15T20:56:00.001-07:00</published><updated>2013-09-15T20:56:08.185-07:00</updated><title type='text'>கட்டாயம் வைத்திருக்க வேண்டிய இலவச மென்பொருட்கள்</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h5 class="uiStreamMessage userContentWrapper" data-ft="{&quot;type&quot;:1,&quot;tn&quot;:&quot;K&quot;}" style="background-color: white; font-family: 'lucida grande', tahoma, verdana, arial, sans-serif; font-size: 11px; font-weight: normal; line-height: 14px; margin: 0px 0px 5px; padding: 0px; word-break: break-word; word-wrap: break-word;">
<span class="messageBody" data-ft="{&quot;type&quot;:3,&quot;tn&quot;:&quot;K&quot;}" style="color: #333333; font-size: 13px; line-height: 1.38;">மென்பொருட்கள் இல்லாமல் நாம் கணினியை பயன்படுத்தவே முடியாது. நம்முடைய அத்தனை செயல்களும் ஏதோ ஒரு மென்பொருளை சார்ந்தே இருக்கும். இதில் நிறைய மென்பொருட்கள் நமக்கு இலவசமாகவே கிடைக்கின்றன. அதில் சில நமக்கு கட்டாயம் தேவைப்படும் அவற்றைப் பற்றி பார்ப்போம்.<span class="text_exposed_show" style="display: inline;"><br /><br />~~Browser~~<br /><br />ப்ரௌசர் என்பது இல்லாமல் நீங்கள் இப்போது இந்த பதிவை படிக்க முடியாது. இணையத்தில் நாம் செயல்பட ப்ரௌசர் ஒரு கட்டாய தேவை. இதில் சிறந்த இரண்டு.<br /><br />1. Chrome -&nbsp;<a href="http://goo.gl/j11of" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/j11of</a><br />2. Firefox -&nbsp;<a href="http://goo.gl/7ICv2" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/7ICv2</a><br /><br />~~Antivirus~~<br /><br />அடிக்கடி பென்டிரைவ் அல்லது இணையத்தில் இருந்து டவுன்லோட் செய்யும் போது நம் கணினியில் வைரஸ் வர வாய்ப்பு உள்ளது. அம்மாதிரியான தருணங்களில் அவற்றை தடுக்கவோ அல்லது தவிர்க்கவோ ஒரு ஆண்டி வைரஸ் மென்பொருள் தேவை. அவற்றில் சிறந்த இரண்டு.<br /><br />1. Avast -&nbsp;<a href="http://goo.gl/8Br5g" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/8Br5g</a><br />2. Microsoft Security Essentials -&nbsp;<a href="http://goo.gl/YDpJ7" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/YDpJ7</a><br /><br />~~File Compression Software~~<br /><br />File Compression Software என்பது நாம் அடிக்கடி பயன்படுத்தும் ஒன்று. இதில் winzip மற்றும் winrar போன்றவை கட்டண மென்பொருட்கள். இதை செய்ய சிறந்த இலவச மென்பொருட்கள்.<br /><br />1. 7-Zip -&nbsp;<a href="http://www.facebook.com/l.php?u=http%3A%2F%2Fgoo.gl%2FCHqRw&amp;h=-AQGjzylrAQH2Qjq1kRQQAPeEoFIfQnt2-Guvi3PNN4kjog&amp;s=1" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/CHqRw</a><br />2. Zip2Fix -&nbsp;<a href="http://goo.gl/y1m9E" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/y1m9E</a><br /><br />~~Image/Graphics editor, paint program, and picture organizer~~<br /><br />இமேஜ் எடிட்டர் என்பது நமக்கு அடிக்கடி தேவைப்படும் ஒன்று. இதில் பெரும்பாலான மென்பொருட்கள் நமக்கு இலவசமாக கிடைப்பது இல்லை. ஆனால் சில நமக்கு இலவசமாக பல வசதிகளை தருகின்றன. அவற்றில் சிறந்தவை.<br /><br />1. Gimpshop -&nbsp;<a href="http://goo.gl/UK9s" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/UK9s</a><br />2. Paint.NET -&nbsp;<a href="http://goo.gl/59FB" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/59FB</a><br />3. IrfanView -&nbsp;<a href="http://goo.gl/59FB" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/59FB</a><br />4. Inkscape -&nbsp;<a href="http://goo.gl/q6Sh" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/q6Sh</a><br /><br />~~Multimedia~~<br /><br />கணினியில் ஓய்வு நேரங்களில் நாம் செய்வது பாடல்கள் கேட்பது மற்றும் படங்கள் பார்ப்பது. அத்தோடு Video Editor, Video Converter போன்றவை தொழில்ரீதியாக உள்ள Multimedia Tools. இதில் சிறந்த இலவச மென்பொருட்கள்.<br /><br />1. VLC media player -&nbsp;<a href="http://www.facebook.com/l.php?u=http%3A%2F%2Fgoo.gl%2FoRNqK&amp;h=WAQFEYWelAQHSRaQ2Shci7S9dYgWKMI2xf9CjOnqZPJhTvg&amp;s=1" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/oRNqK</a><br />2. KM Player -&nbsp;<a href="http://goo.gl/VMzX7" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/VMzX7</a><br />3. Audacity – Free Audio Editor -&nbsp;<a href="http://www.facebook.com/l.php?u=http%3A%2F%2Fgoo.gl%2FARs0&amp;h=jAQHane1dAQELjUiSJzxNCuHmeACwAb_QlxdlrjjgfRlt8g&amp;s=1" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/ARs0</a><br />4. Avidemux – Free Video Editor -&nbsp;<a href="http://www.facebook.com/l.php?u=http%3A%2F%2Fgoo.gl%2FUzr2n&amp;h=KAQGV66t9AQElJSCpOVwUA3ueFNfm3qR5N67bUHHUS6b2SQ&amp;s=1" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/Uzr2n</a><br />5. DVD Video Soft -&nbsp;<a href="http://www.facebook.com/l.php?u=http%3A%2F%2Fgoo.gl%2Fw6Hhj&amp;h=EAQGD-yQ0AQG82FwqyvbQh84u4CLEdfPjt4KOBR0lBccxKg&amp;s=1" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/w6Hhj</a><br />6. Free Make Video Converter -&nbsp;<a href="http://www.facebook.com/l.php?u=http%3A%2F%2Fgoo.gl%2FHyb9J&amp;h=8AQEv2vz6AQGBFi6kzKsg8Q3dJ_KSj-IW5dRnfpCygu0fMQ&amp;s=1" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/Hyb9J</a><br /><br />~~~Office Tools~~<br /><br />MS Office க்கு மாற்றாக பல இலவச மென்பொருட்கள் உள்ளன. அவற்றில் சிறந்தவை.<br /><br />1. MS Officeக்கு மாற்றாக சில இலவச மென்பொருட்கள் -<a href="http://goo.gl/XuiAM" rel="nofollow nofollow" style="color: #3b5998; cursor: pointer; text-decoration: none;" target="_blank">http://goo.gl/XuiAM</a></span></span></h5>
<h5 class="uiStreamMessage userContentWrapper" data-ft="{&quot;type&quot;:1,&quot;tn&quot;:&quot;K&quot;}" style="background-color: white; font-family: 'lucida grande', tahoma, verdana, arial, sans-serif; font-size: 11px; font-weight: normal; line-height: 14px; margin: 0px 0px 5px; padding: 0px; word-break: break-word; word-wrap: break-word;">
<div class="mvm uiStreamAttachments fbMainStreamAttachment" data-ft="{&quot;type&quot;:10,&quot;tn&quot;:&quot;H&quot;}" style="color: #333333; margin-bottom: 10px; margin-top: 10px;">
<div class="clearfix photoRedesign" style="width: 398px; zoom: 1;">
<a ajaxify="https://www.facebook.com/photo.php?fbid=626772577353395&amp;set=a.295437630486893.76949.293309174033072&amp;type=1&amp;relevant_count=1&amp;ref=nf&amp;src=https%3A%2F%2Ffbcdn-sphotos-c-a.akamaihd.net%2Fhphotos-ak-prn2%2F1240543_626772577353395_454400939_n.jpg&amp;size=681%2C720&amp;source=12" class="uiPhotoThumb photoRedesignAspect" data-ft="{&quot;type&quot;:41,&quot;tn&quot;:&quot;E&quot;}" href="https://www.facebook.com/photo.php?fbid=626772577353395&amp;set=a.295437630486893.76949.293309174033072&amp;type=1&amp;relevant_count=1&amp;ref=nf" rel="theater" style="border: 0px; color: #3b5998; cursor: pointer; display: block; float: left; position: relative; text-decoration: none;" title=""><div class="uiScaledImageContainer photoWrap" style="height: 338px; overflow: hidden; position: relative; width: 320px;" title="">
<img alt="" class="scaledImageFitWidth img" height="338" src="https://fbcdn-sphotos-c-a.akamaihd.net/hphotos-ak-prn2/p320x320/1240543_626772577353395_454400939_n.jpg" style="border: 0px; display: block; height: auto; margin: 0px; max-width: none; min-height: 100%; position: relative; width: 320px;" title="" width="320" /></div>
</a></div>
</div>
</h5>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/7406934568444607046/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/09/blog-post.html#comment-form' title='1 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7406934568444607046'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7406934568444607046'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/09/blog-post.html' title='கட்டாயம் வைத்திருக்க வேண்டிய இலவச மென்பொருட்கள்'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>1</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-5861097863378326499</id><published>2013-08-08T04:59:00.000-07:00</published><updated>2013-08-08T04:59:02.565-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 16</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; text-align: justify;">இன்றைய பாகம்-16ல் SQL ன் Aggregate Functions மற்றும், Grouping போன்றவற்றைக் காணலாம்.</span></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<br style="margin: 0px; padding: 0px;" />இதற்கான ஒரு மாதிரி Table Structure கீழே:<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEipxWBllh1rvjeef0jCeT5SkcF_ck2VICq5hI3eqJxSx5bJJj472zpowrd72tEKWKsRLhXssIoCCkT-TRV4njhxC3VQGE4JIzeR7vx1qlm5SmcGaU4jYctm82Nih_6TfLL0tV_Dv31oT-s3/s1600-h/sampletablestructure.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302083641128054290" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEipxWBllh1rvjeef0jCeT5SkcF_ck2VICq5hI3eqJxSx5bJJj472zpowrd72tEKWKsRLhXssIoCCkT-TRV4njhxC3VQGE4JIzeR7vx1qlm5SmcGaU4jYctm82Nih_6TfLL0tV_Dv31oT-s3/s320/sampletablestructure.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 76px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த Table ஐப் பயன்படுத்தி இன்றையப் பாகத்தைத் தொடருவோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Aggregate Functions என்றால் என்ன?</span><br style="margin: 0px; padding: 0px;" />SUM, AVG, MIN, MAX, COUNT போன்றவற்றைப் பயன்படுத்தி கணித விடை காணல். இதன் விடையாக ஒரே ஒரு மதிப்பு மட்டும் வெளியாகும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjL-hWYunnLCn4so7b4SvYXTspTulPHFLPs5xzjqaK45mFaXlyav1KsXfTXlh_-GdxMLJeNINDMJDNPEGBdxtwJIzXKvIc0cRzyUV5y4hVZKOS2JDb65NbrEJoqVeHITGhcVX6657k6VQ9y/s1600-h/sampledata.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302085388160541634" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjL-hWYunnLCn4so7b4SvYXTspTulPHFLPs5xzjqaK45mFaXlyav1KsXfTXlh_-GdxMLJeNINDMJDNPEGBdxtwJIzXKvIc0cRzyUV5y4hVZKOS2JDb65NbrEJoqVeHITGhcVX6657k6VQ9y/s320/sampledata.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 320px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 301px;" /></a><br style="margin: 0px; padding: 0px;" />இந்த Tableல் மணி, வீரன், சந்த்ரு, ஹாரிஸ் ஆகிய 3 விற்பனையாளர்களும் வெவ்வேறு காலகட்டங்களில் வேறு வேறு பகுதிகளில் எவ்வளவு தொகைக்கு விற்பனை செய்துள்ளனர் என்பதை அறியக் கொடுத்துள்ளேன்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அனைவரும் சேர்ந்து ஒட்டுமொத்தமாக எவ்வளவு தொகைக்குப் பொருட்களை விற்பனை செய்துள்ளனர். இதற்கு SUM பயன்படுத்தலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒட்டுமொத்தமான கூடுதல் தொகை.<br style="margin: 0px; padding: 0px;" />SELECT SUM(SaleAmount) AS [Total Sale Amount] from Sales<br style="margin: 0px; padding: 0px;" />விடை : 59310<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அதிகபட்சமாக விற்பனையான தொகை<br style="margin: 0px; padding: 0px;" />SELECT MAX(SaleAmount) AS [Maximum] from Sales<br style="margin: 0px; padding: 0px;" />விடை : 7800<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />குறைந்தபட்சமாக விற்பனையான தொகை<br style="margin: 0px; padding: 0px;" />SELECT MIN(SaleAmount) AS [Minimum] from Sales<br style="margin: 0px; padding: 0px;" />விடை : 400<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />சராசரித் தொகை<br style="margin: 0px; padding: 0px;" />SELECT AVG(SaleAmount) AS [Average] from Sales<br style="margin: 0px; padding: 0px;" />விடை : 3954.000000<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />மொத்தத்தில் எத்தனை முறை விற்பனை நடந்துள்ளது?<br style="margin: 0px; padding: 0px;" />SELECT count(*) AS [Total Transactions] from Sales<br style="margin: 0px; padding: 0px;" />விடை : 15<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />மொத்தம் எத்தனை விற்பனையாளர்கள் ?<br style="margin: 0px; padding: 0px;" />SELECT COUNT(DISTINCT SalesMan)AS [Total Persons Involved] FROM Sales<br style="margin: 0px; padding: 0px;" />விடை:4<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே மாதிரி Tableல் ஒவ்வொரு பிரதிநிதிகளும், ஒன்றுக்கு மேற்பட்டமுறை விற்பனை செய்துள்ளனர். ஆதலால் ஒவ்வொரு பிரதிநிதியின் தனிப்பட்ட கூடுதல், அதிகபட்ச / குறைந்தபட்ச விற்பனைத்தொகை முதலியவற்றைக் காண்பதற்கு GROUP BY பயன்படுத்தலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒவ்வொருவரின் தனிப்பட்ட விற்பனைத்தொகையைக் காண<br style="margin: 0px; padding: 0px;" />SELECT SalesMan,SUM(SaleAmount) as [Individual SaleAmount]<br style="margin: 0px; padding: 0px;" />FROM Sales GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />விடை :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEitT1nqChvYY0iIfdzI-ROys4ty3ODdDkR5RNCbYA-v96wZ-63hynogxq1RLPSfwEprfgJYAX1744a6jzDPWDWP7JOVj2V2KaklJEet4vrSdugwIjLZXH-NtjCXx4MnIWZAcNAzBzmkN3Al/s1600-h/sumgroup.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302090531982722770" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEitT1nqChvYY0iIfdzI-ROys4ty3ODdDkR5RNCbYA-v96wZ-63hynogxq1RLPSfwEprfgJYAX1744a6jzDPWDWP7JOVj2V2KaklJEet4vrSdugwIjLZXH-NtjCXx4MnIWZAcNAzBzmkN3Al/s320/sumgroup.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 96px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 184px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒவ்வொருவரின் அதிகபட்ச விற்பனைத்தொகையைக் காண்பதற்கு<br style="margin: 0px; padding: 0px;" />SELECT SalesMan,MAX(SaleAmount) as [Individual Max Efficiency]<br style="margin: 0px; padding: 0px;" />FROM Sales GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhP5_aKS-HO5mwYuBSUcPP8VR5Yi9XtCpG83Ne_TlhGD5O8wbQvpY_GHsE73cbdHi7-SCqqkMflvt_fpAEigKEyLrigSg_xuDZY037IsZnUhY8HJ0NzkTQK7iS68INx6Rh7Gdwhi5qhmT83/s1600-h/maxeffibyeach.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302091050922586082" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhP5_aKS-HO5mwYuBSUcPP8VR5Yi9XtCpG83Ne_TlhGD5O8wbQvpY_GHsE73cbdHi7-SCqqkMflvt_fpAEigKEyLrigSg_xuDZY037IsZnUhY8HJ0NzkTQK7iS68INx6Rh7Gdwhi5qhmT83/s320/maxeffibyeach.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 94px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 191px;" /></a>ஒவ்வொருவரின் குறைந்தபட்ச திறனைக் காண<br style="margin: 0px; padding: 0px;" />SELECT SalesMan,MIN(SaleAmount) as [Individual Min Amt] FROM Sales GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEibJjqN0x_6Njjb7GGTjPg1y6TJftQsiYYiQGdNVTR2jAUZWL3OOGXEnPGp8ml2g_LMVdzxeWV0NrZs46yZy0_BJGfpARwRIbV0dZGs5ap8ICD6CXNPmTlej4gNGmWRAd6RI3w4nOsUhK_d/s1600-h/mineff.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302091609990158130" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEibJjqN0x_6Njjb7GGTjPg1y6TJftQsiYYiQGdNVTR2jAUZWL3OOGXEnPGp8ml2g_LMVdzxeWV0NrZs46yZy0_BJGfpARwRIbV0dZGs5ap8ICD6CXNPmTlej4gNGmWRAd6RI3w4nOsUhK_d/s320/mineff.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 96px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 163px;" /></a><br style="margin: 0px; padding: 0px;" />SELECT உடன் மேலும் அதிகமான கட்டுப்பாடுகளை விதிப்பதற்கும் Conditionகளைக் கூறுவதற்கும் WHERE சேர்த்துப் பயன்படுத்துவோம். அதுபோல இங்கே Aggregate Functions பயன்படுத்தும்போது HAVING ஐ இணைத்துப் பயன்படுத்துவோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />விற்பனைப் பிரதிநிதிகளின் இரண்டாவது எழுத்து 'a' ஆக உள்ளவர்களையும், அவர்களது ஒட்டுமொத்த விற்றதொகையையும் காண<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT SalesMan,SUM(SaleAmount) as [Individual SaleAmount]<br style="margin: 0px; padding: 0px;" />FROM Sales GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" />HAVING SalesMan LIKE '_a%'<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiDSl_xs-5UUlxmLs1n0ScFpQYTXRsSI1OO2CK1Advo56A8NfeqCk5N7tk9cQ8TrySYu8av_pVtF3YJpSJlpQAs4yQ6wYyooOPgDli60fSZg6tyKaAdcyBx72rQvgpcSLQQPbof9rkJW1QP/s1600-h/secondLetterA.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302092944195608578" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiDSl_xs-5UUlxmLs1n0ScFpQYTXRsSI1OO2CK1Advo56A8NfeqCk5N7tk9cQ8TrySYu8av_pVtF3YJpSJlpQAs4yQ6wYyooOPgDli60fSZg6tyKaAdcyBx72rQvgpcSLQQPbof9rkJW1QP/s320/secondLetterA.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 57px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 181px;" /></a>_ மற்றும் % ஆகிய அடையாளங்களுக்கு Wild card characters என்று பெயர். அதாவது இட நிரப்பிகள். _ என்பது ஒரு எழுத்தை மட்டும் நிரப்பும். % என்பது அனைத்து எழுத்துகளையும் நிரப்பும்.<br style="margin: 0px; padding: 0px;" />‘_a%' என்றால் முதல் எழுத்து ஏதோ ஒன்றாகவும், கண்டிப்பாக இரண்டாம் எழுத்து 'a' பிற எழுத்துகளைப் பற்றிக் கவலையில்லை. இப்படி எந்த பிரதிநிதியின் பெயரில் இரண்டாவது எழுத்து 'a' வருகிறதோ அவர்களை மட்டும் காண்பதற்கு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒட்டுமொத்தத்தில் 20000 ஐ விட அதிகமாக விற்பனை செய்தவர்களை மட்டும் காண்பதற்கு:<br style="margin: 0px; padding: 0px;" />SELECT SalesMan, SUM(SaleAmount) as [Individual SaleAmount] FROM Sales<br style="margin: 0px; padding: 0px;" />GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" />HAVING SUM(SaleAmount) &gt; 20000<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjzXi5PA1yCQDGLODILNx1AysVzvlVTaD1ukpsk8zYk-RUssQ2TsyQpHSiLg5Owxt60469wDtzWlzeG6y0RDTPu1S5Ap5Pbmj2sNcDHCvdKUYz0NiOjIUBaX5lszJGwgdHbZOF_S-IG0q5m/s1600-h/greater20K.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302094033565227330" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjzXi5PA1yCQDGLODILNx1AysVzvlVTaD1ukpsk8zYk-RUssQ2TsyQpHSiLg5Owxt60469wDtzWlzeG6y0RDTPu1S5Ap5Pbmj2sNcDHCvdKUYz0NiOjIUBaX5lszJGwgdHbZOF_S-IG0q5m/s320/greater20K.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 57px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 181px;" /></a>மொத்தவிற்பனை 5000 ரூபாயைவிடக் குறைவாக விற்றவர் யார்?<br style="margin: 0px; padding: 0px;" />SELECT SalesMan,SUM(SaleAmount) as [Individual SaleAmount] FROM Sales<br style="margin: 0px; padding: 0px;" />GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" />HAVING SUM(SaleAmount)<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjV2XRjuAKkDZVqtX-LsxWq3c-VY-WcHwaj3bZVJgGhorlz1IXJyx8QuDP4UCj5cdJY38yGsPtt7RQ48-Na_dTvlLSWSnPcC53FclZJg_GR35cx2CtMwMEIyLyipcEfCGN6Gd1hhtcDpLGa/s1600-h/lessthan5K.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302094651889442594" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjV2XRjuAKkDZVqtX-LsxWq3c-VY-WcHwaj3bZVJgGhorlz1IXJyx8QuDP4UCj5cdJY38yGsPtt7RQ48-Na_dTvlLSWSnPcC53FclZJg_GR35cx2CtMwMEIyLyipcEfCGN6Gd1hhtcDpLGa/s320/lessthan5K.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 39px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 182px;" /></a>5000 ரூபாய்கள் முதல் 20000 ரூபாய்கள் வரை விற்பனை செய்தோர் யாவர்?<br style="margin: 0px; padding: 0px;" />SELECT SalesMan,SUM(SaleAmount) as [Individual SaleAmount] FROM Sales<br style="margin: 0px; padding: 0px;" />GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" />HAVING SUM(SaleAmount) BETWEEN 1000 AND 20000<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjfEx5HRJQndSMfxXZmrpjsS7KSInxSvDLdBg295n4yohd5MiHV0jv7-kZ6LVhJBODbG1HeSGhnRwJ1Jj4dNSsKCuE8ISnmzvNNvuuYBRAxdN6E9wgkYymtKKjzNDXtj1Q5yX2Or-m9fTay/s1600-h/5K220K.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302095207356199602" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjfEx5HRJQndSMfxXZmrpjsS7KSInxSvDLdBg295n4yohd5MiHV0jv7-kZ6LVhJBODbG1HeSGhnRwJ1Jj4dNSsKCuE8ISnmzvNNvuuYBRAxdN6E9wgkYymtKKjzNDXtj1Q5yX2Or-m9fTay/s320/5K220K.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 59px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 185px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />கீழே உள்ளதைக் கவனிக்கவும்.<br style="margin: 0px; padding: 0px;" />SELECT SalesMan, SUM(SaleAmount) as [TotalSales], MAX(SaleAmount) as [Maximum], Min(SaleAmount) as [Minimum], count(SaleAmount)as [TotalTransaction] from Sales<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />நான் எதையோ எதிர்பார்த்து இப்படிக் கொடுத்தால் என்ன ஆகும். Sum, Max, Min, Count அனைத்தையும் கொடுத்துள்ளேன். ஆனால் GROUP BY மட்டும் கொடுக்காமல் விட்டுவிட்டேன். இப்போது என்ன ஆகும்?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />கீழேயுள்ள பிழைச்செய்திதான் கிடைக்கும். குழுவாகப் பிரித்து ஒவ்வொருவரின் தனித்திறமையைக் காண்பதற்கே GROUP BY பயன்படுகிறது.<br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Msg 8120, Level 16, State 1, Line 1</span><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Column 'Sales.SalesMan' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதைச் சரிசெய்த பிறகு,<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT SalesMan, SUM(SaleAmount) as [TotalSales], MAX(SaleAmount) as [Maximum], Min(SaleAmount) as [Minimum], count(SaleAmount)as [TotalTransaction]<br style="margin: 0px; padding: 0px;" />from Sales<br style="margin: 0px; padding: 0px;" />GROUP BY SalesMan<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் விடை:<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhPLsi758yj8UgwK2DSFB4jPDhWZfHT5kkRhMd0BSn_4UGiH6CB7zY5R5J7FjHhG3V_2kjBjj4n_2Bye3y5_Jp4kexcpzDxUO5fDSfEEqA3DYmwes_2hCZf5QdIRhUXmWxLAQoUKEHjgbPu/s1600-h/finaltab.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5302098504284581442" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhPLsi758yj8UgwK2DSFB4jPDhWZfHT5kkRhMd0BSn_4UGiH6CB7zY5R5J7FjHhG3V_2kjBjj4n_2Bye3y5_Jp4kexcpzDxUO5fDSfEEqA3DYmwes_2hCZf5QdIRhUXmWxLAQoUKEHjgbPu/s320/finaltab.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 92px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a></div>
<div>
<br /></div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/5861097863378326499/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-16.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5861097863378326499'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5861097863378326499'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-16.html' title='எளிய தமிழில் SQL - பாகம் 16'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEipxWBllh1rvjeef0jCeT5SkcF_ck2VICq5hI3eqJxSx5bJJj472zpowrd72tEKWKsRLhXssIoCCkT-TRV4njhxC3VQGE4JIzeR7vx1qlm5SmcGaU4jYctm82Nih_6TfLL0tV_Dv31oT-s3/s72-c/sampletablestructure.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-2824736612234916602</id><published>2013-08-08T04:58:00.002-07:00</published><updated>2013-08-08T04:58:29.573-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 15</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<span style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; text-align: justify;">இன்றைய பாகம் 15ல் இரண்டு tableகளை இணைப்பது குறித்து இன்னும் விவரமாகப் பார்க்க இருக்கிறோம்.</span><br />
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<br style="margin: 0px; padding: 0px;" />பாகம் 14ல் Primarykey மற்றும் Foreign key ஆகியவற்றைப் பயன்படுத்துவது என்பது குறித்துப் பார்த்தோம். அதன் தொடர்ச்சியாக இதைக் கொண்டாலும் இதில் சில விதிவிலக்குகள் புரிதலுக்காகச் செய்திருக்கிறேன்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒன்றுக்கு மேற்பட்ட Tableகளை இணைத்து அனைத்து அறிக்கைகளையும் ஒரே திரையில் காண்பதற்கு JOIN பயன்படுத்தப்படுகிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />JOINன் வகைகள்<br style="margin: 0px; padding: 0px;" />INNER JOIN<br style="margin: 0px; padding: 0px;" />OUTER JOIN<br style="margin: 0px; padding: 0px;" />SELF JOIN<br style="margin: 0px; padding: 0px;" />CROSS JOIN<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />OUTER JOIN ஐ இன்னும் 3 வகை உட்பிரிவுகளாகப் பிரித்து, LEFT OUTER, RIGHT OUTER, FULL OUTER எனப் பிரிக்கலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே மாதிரிக்காக 2 tableகளை உருவாக்கி அவற்றில் சில மாதிரி records ஐ ஏற்றியிருக்கிறேன். அவற்றின் பெயர்கள் Author மற்றும் Publication ஆகியவை.<br style="margin: 0px; padding: 0px;" />Author அட்டவணையின் Structure மற்றும் மாதிரி தகவல்கள் ஆகியவை கீழே:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiMv_oQH0IR7QPn635YeptaUyOSW6VcQ_zM7bw6eTB2CIq_TCaHnzIWWnclvnsryQrUEheXBzdqHN5e86LkLNopkjAftY3QEa9TSxdtseKdTzJ4zEkunRlsqlc40n2GL_WCX0uHUuyWmQvH/s1600-h/AuthorStructure.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301176093732399922" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiMv_oQH0IR7QPn635YeptaUyOSW6VcQ_zM7bw6eTB2CIq_TCaHnzIWWnclvnsryQrUEheXBzdqHN5e86LkLNopkjAftY3QEa9TSxdtseKdTzJ4zEkunRlsqlc40n2GL_WCX0uHUuyWmQvH/s320/AuthorStructure.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 40px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 315px;" /></a><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhjGLV5dCDb0guXyduICzWoh_xkqeV2CMTjHhJniZCnJL8m0HiOxA-XJqXwEEP_qzV6ZoWXR_QEIZoOl_xJbBZcf-eGXnauD4tGUHf-ghtJahQ3mNEhLokI1okWVtC7lAwFoqVNUw0Rq-Q0/s1600-h/AuthorSampleData.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301178124659191058" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhjGLV5dCDb0guXyduICzWoh_xkqeV2CMTjHhJniZCnJL8m0HiOxA-XJqXwEEP_qzV6ZoWXR_QEIZoOl_xJbBZcf-eGXnauD4tGUHf-ghtJahQ3mNEhLokI1okWVtC7lAwFoqVNUw0Rq-Q0/s320/AuthorSampleData.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 229px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 201px;" /></a>Publication அட்டவணையின் Structure Structure மற்றும் மாதிரி தகவல்கள் ஆகியவை கீழே:<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEimPorQzkW9nHACHCo6XQqsahbDEFdfV2XACAGq0JvSxm-XUTt9iq7Wg_7YsfyMR2NK4HRwQxT-8R7sx4V1pEcphUgXIGVQ3adBGA_jg5QrhSSXSlUbHOyv-UrqDtFySgJHMbcTo-dE-GDI/s1600-h/publicationstructure.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301176591078741954" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEimPorQzkW9nHACHCo6XQqsahbDEFdfV2XACAGq0JvSxm-XUTt9iq7Wg_7YsfyMR2NK4HRwQxT-8R7sx4V1pEcphUgXIGVQ3adBGA_jg5QrhSSXSlUbHOyv-UrqDtFySgJHMbcTo-dE-GDI/s320/publicationstructure.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 60px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 317px;" /></a><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEigTpMSmha9VuKTIVyK93olKyy26rT2tevbvvUg246VRYEf_u5kte9MQhoLjaY84Yqn9m7eAZVY7TlWNmFYiSA8UgFWpBrbDt3bFJABPZJIos7p988TacOx-RMOvUx-yweGAv8mHmG_b9aJ/s1600-h/publicationsampledata.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301178121740158466" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEigTpMSmha9VuKTIVyK93olKyy26rT2tevbvvUg246VRYEf_u5kte9MQhoLjaY84Yqn9m7eAZVY7TlWNmFYiSA8UgFWpBrbDt3bFJABPZJIos7p988TacOx-RMOvUx-yweGAv8mHmG_b9aJ/s320/publicationsampledata.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 320px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 270px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எழுத்தாளர் அட்டவணையில் உள்ள முதல் 4 Authorகள் பதிப்பக அட்டவணையில் வேறுவேறு நூல்களை எழுதி இருக்கின்றனர். ஆனால் மீதமுள்ள 6 எழுத்தாளர்கள் எழுதிய நூல்களின் விவரங்கள் பதிப்பக அட்டவணையில் இல்லை.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அதேபோல பதிப்பக அட்டவணையில் உள்ள குறிப்பிட்ட Chicken Special முதல் Making of Nandha வரையிலான புத்தகங்களின் எழுத்தாளர்கள் பற்றிய விவரங்கள் Author அட்டவணையில் இல்லை. இது ஒரு மாதிரிக்காக உருவாக்கப்பட்ட tableகள். இவற்றின் மூலம் நாம் tableகளை இணைக்கும் JOIN பற்றி எளிதாக அறிந்துகொள்ளலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />முதலில் INNER JOIN பற்றிப் பார்ப்போம். அதன் Syntax கீழே:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT table1.Field1, table1.Field2, table2.Field1, table2.Field2<br style="margin: 0px; padding: 0px;" />FROM<br style="margin: 0px; padding: 0px;" />table1 INNER JOIN table2<br style="margin: 0px; padding: 0px;" />ON<br style="margin: 0px; padding: 0px;" />table1.CommonField = table2.CommonField<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே table1 = Author , table2 = Publication என அறிக.<br style="margin: 0px; padding: 0px;" />இதற்கான உதாரணத்தைக் கவனிக்கவும்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT Author.AuthorID, Author.AuthorName, Publication.BookName<br style="margin: 0px; padding: 0px;" />FROM Author INNER JOIN<br style="margin: 0px; padding: 0px;" />Publication ON Author.AuthorID = Publication.AuthorID<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் விடை:<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjBayH7AivTzrTXGN7wwNHbcqQE98N0vaVyLqlUWgaYSRSGcX_GCku8p0AbyG3X6ifqlJ8LXqdzkywmeLIxArNsZ3P9dGGW0E6FBWAcb0qOzTtZhIBUTkzfGEtcv30vLuIAcTiAPKRM1klg/s1600-h/inner.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301181060439796082" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjBayH7AivTzrTXGN7wwNHbcqQE98N0vaVyLqlUWgaYSRSGcX_GCku8p0AbyG3X6ifqlJ8LXqdzkywmeLIxArNsZ3P9dGGW0E6FBWAcb0qOzTtZhIBUTkzfGEtcv30vLuIAcTiAPKRM1klg/s320/inner.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 189px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 276px;" /></a><br style="margin: 0px; padding: 0px;" />இங்கே இரண்டு tableகளுக்கும் பொதுவாக அமைந்துள்ள rows மட்டுமே இடம்பெற்றுள்ளன.<br style="margin: 0px; padding: 0px;" />Author அட்டவணையிலும், Publication அட்டவணையிலும் வண்ணமிட்டுக் காட்டப்பட்ட தகவல்களைக் காணவில்லை. பொதுவாக உள்ளவை மட்டுமே இடம்பெற்றுள்ளன. கீழேயுள்ள கணம் பற்றிய படத்தைக் கவனிக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEihtfy_4FLBCgAQbzeH5XEcf8u2mah6UVoFK3CFCn9zpsuLGXpnpAqS7XflBvPflW7WSceW3gYuzkRHl-Z1rt19Nqedk-u3GJ72RZT1HLd8i_N42Klg4RNtExjwnWcNcgERw-wOafthWjN-/s1600-h/inner.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301183857540574290" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEihtfy_4FLBCgAQbzeH5XEcf8u2mah6UVoFK3CFCn9zpsuLGXpnpAqS7XflBvPflW7WSceW3gYuzkRHl-Z1rt19Nqedk-u3GJ72RZT1HLd8i_N42Klg4RNtExjwnWcNcgERw-wOafthWjN-/s320/inner.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 188px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />LEFT OUTER JOIN பற்றிப் பார்ப்போம். அதன் Syntax கீழே:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT table1.Field1, table1.Field2, table2.Field1, table2.Field2<br style="margin: 0px; padding: 0px;" />FROM<br style="margin: 0px; padding: 0px;" />table1 LEFT OUTER JOIN table2<br style="margin: 0px; padding: 0px;" />ON<br style="margin: 0px; padding: 0px;" />table1.CommonField = table2.CommonField<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே table1 = Author , table2 = Publication என அறிக.<br style="margin: 0px; padding: 0px;" />இதற்கான உதாரணத்தைக் கவனிக்கவும்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT Author.AuthorID, Author.AuthorName, Publication.BookName<br style="margin: 0px; padding: 0px;" />FROM Author LEFT OUTER JOIN<br style="margin: 0px; padding: 0px;" />Publication ON Author.AuthorID = Publication.AuthorID<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் விடை:<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgtZV9zR7PYQSqKdnU6G5XoOMksjBh8B7qAHnX8hycFZef0rw666uZfxK3-aNuX4obBy59ffXrWutlRuISl0ggZpSSObNSGAOzppQf0QgftSmdC4hVXWEbxgKhjdcqV1nvodg5BBcLk38lV/s1600-h/leftoutersampledata.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301184827667190290" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgtZV9zR7PYQSqKdnU6G5XoOMksjBh8B7qAHnX8hycFZef0rw666uZfxK3-aNuX4obBy59ffXrWutlRuISl0ggZpSSObNSGAOzppQf0QgftSmdC4hVXWEbxgKhjdcqV1nvodg5BBcLk38lV/s320/leftoutersampledata.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 308px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 274px;" /></a>இங்கே முதலாவது table ஆகிய Author ல் இருக்கும் அனைத்து rowsஇடம் பெற்றுள்ளன. ஒரே எழுத்தாளர் ஒன்றுக்கு மேற்பட்ட புத்தகங்களை எழுதியுள்ளதால் அவர்கள் திரும்பத்திரும்ப இடம்பெற்றிருக்கிறார்கள்.<br style="margin: 0px; padding: 0px;" />5 முதல் 10 வரையிலான எழுத்தாளர்கள் எழுதிய புத்தகங்கள் Publication அட்டவணையில் இல்லாததால் அவர்களுக்கு நேரே உள்ள BookName ல் NULL மூலம் நிரப்பப்பட்டுவிட்டது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இடதுபுற (Left side = Author) அட்டவணையில் எல்லா recordsம் தேர்வுசெய்யப்பட்டுவிடும். ஆனால் வலது புறத்தில் உறவுமுறை (Relation) இல்லாத rows எல்லாவற்றிலும் NULL நிரப்பப்பட்டுக் காண்பிக்கப்படும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgl5uOxtDB36a8hsye0tXXTAlI_IMy_ejaUiz_xMulHcOhCmOrvBHU9zvrMWPVQfkI3rRFgCY1wM86_5uBaPH_nAsOLRZQ-IpvidGnODKFJDW0OiBYTBVQ0bpbcnv9ZViKNvauNHXxPXZTV/s1600-h/leftouter.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301189921398596994" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgl5uOxtDB36a8hsye0tXXTAlI_IMy_ejaUiz_xMulHcOhCmOrvBHU9zvrMWPVQfkI3rRFgCY1wM86_5uBaPH_nAsOLRZQ-IpvidGnODKFJDW0OiBYTBVQ0bpbcnv9ZViKNvauNHXxPXZTV/s320/leftouter.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 205px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 236px;" /></a><br style="margin: 0px; padding: 0px;" />மேலே காட்டப்பட்டிருக்கு கணம் பற்றிய படத்தைக் கவனிக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />RIGHT OUTER JOIN பற்றிப் பார்ப்போம். அதன் Syntax கீழே:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT table1.Field1, table1.Field2, table2.Field1, table2.Field2,table2.Field3<br style="margin: 0px; padding: 0px;" />FROM<br style="margin: 0px; padding: 0px;" />table1 RIGHT OUTER JOIN table2<br style="margin: 0px; padding: 0px;" />ON<br style="margin: 0px; padding: 0px;" />table1.CommonField = table2.CommonField<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே table1 = Author , table2 = Publication என அறிக.<br style="margin: 0px; padding: 0px;" />இதற்கான உதாரணத்தைக் கவனிக்கவும்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT Author.AuthorID, Author.AuthorName, Publication.BookName,Publication.Publication<br style="margin: 0px; padding: 0px;" />FROM Author RIGHT OUTER JOIN<br style="margin: 0px; padding: 0px;" />Publication ON Author.AuthorID = Publication.AuthorID<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் விடை: AuthorIDல் 5 முதல் 10 வரையிலான அனைத்து Authorகளைத் தவிர மீதியுள்ளோர் மட்டுமே இடதுபுறம் இடம்பெற்றுள்ளனர். Chicken Special முதல் Making of Nandha வரையிலான நூல்களை எழுதிய Author பற்றிய குறிப்புகள் Author அட்டவணையில் இல்லை - அதனால் அவற்றுக்கு நேராக NULL நிரப்பப்பட்டுவிட்டது. Right Outer Join ல் வலது புறம் (Right side) உள்ள அட்டவணையின் அனைத்து records ம் திரையில் காண்பிக்கப்படும். ஒப்புமை இல்லாத இடதுபுற rowsக்கு மட்டும் NULL நிரப்பப்பட்டுவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgr_42HX-xsOtCw4yqeHfvh0J2TJ-RpAGnUww5CPu8S4-EcvJGOgP_J1zEzSlwrTfRPpZIFXfJ3pVRG3DKCZEoT1ShH9XzeWI7L4EwxDzcdTt2SSrmXdE8t19RrRNqVRkNGRBs0wWZR0NcV/s1600-h/rightouterresultdata.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301187204279746658" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgr_42HX-xsOtCw4yqeHfvh0J2TJ-RpAGnUww5CPu8S4-EcvJGOgP_J1zEzSlwrTfRPpZIFXfJ3pVRG3DKCZEoT1ShH9XzeWI7L4EwxDzcdTt2SSrmXdE8t19RrRNqVRkNGRBs0wWZR0NcV/s320/rightouterresultdata.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 271px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>கீழேயுள்ள கணம் பற்றிய படத்தைக் கவனிக்கவும்.<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiYvsmPFfsVX4bcUX79Hdu1wwoUdTnMIcFCEcfQH2reU1iH8DyOEHLp4_UUM-ARktuQjaycwPbNniMariMQTZZn_RQbSFGObXcQEpbbvmGVraLAPmvxqO60hoE74j42s5A9KcyEJikenk1u/s1600-h/rightouter.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301190797923611826" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiYvsmPFfsVX4bcUX79Hdu1wwoUdTnMIcFCEcfQH2reU1iH8DyOEHLp4_UUM-ARktuQjaycwPbNniMariMQTZZn_RQbSFGObXcQEpbbvmGVraLAPmvxqO60hoE74j42s5A9KcyEJikenk1u/s320/rightouter.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 204px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 220px;" /></a>இப்போது FULL OUTER பற்றிப் பார்ப்போம்.<br style="margin: 0px; padding: 0px;" />அதன் Syntax கீழே:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT table1.Field1, table1.Field2, table2.Field1, table2.Field2,table2.Field3<br style="margin: 0px; padding: 0px;" />FROM<br style="margin: 0px; padding: 0px;" />table1 FULL OUTER JOIN table2<br style="margin: 0px; padding: 0px;" />ON<br style="margin: 0px; padding: 0px;" />table1.CommonField = table2.CommonField<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே table1 = Author , table2 = Publication என அறிக.<br style="margin: 0px; padding: 0px;" />இதற்கான உதாரணத்தைக் கவனிக்கவும்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT Author.AuthorID, Author.AuthorName, Publication.BookName,Publication.Publication<br style="margin: 0px; padding: 0px;" />FROM Author FULL OUTER JOIN<br style="margin: 0px; padding: 0px;" />Publication ON Author.AuthorID = Publication.AuthorID<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் விடை:<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg0nFfqhIR4HrdInL0ZOhg5smRcYzGMtjIuSA0HJPTqkkzfenG6Au_ocOJOu2fAUXiNVWJLzYjK-U8lEpdP34Cp1WrWlh1H7kAjAoEmcf2LKdzY6J8sGR4j8EJoSHftLSLsurdkZu0U1u3L/s1600-h/FULLouterdata.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5301191468281787522" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg0nFfqhIR4HrdInL0ZOhg5smRcYzGMtjIuSA0HJPTqkkzfenG6Au_ocOJOu2fAUXiNVWJLzYjK-U8lEpdP34Cp1WrWlh1H7kAjAoEmcf2LKdzY6J8sGR4j8EJoSHftLSLsurdkZu0U1u3L/s320/FULLouterdata.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 320px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 278px;" /></a><br style="margin: 0px; padding: 0px;" />இரண்டுபுறமுள்ள tableகளிலும் உள்ள பொதுவான rows அதன் இடங்களில் சரியாக இடம்பெற்றுள்ளன. உறவுமுறையில்லாத recordsம் இடம்பெற்றுள்ளன. ஆனால் எங்கெங்கு தகவல்கள் இல்லையோ அங்கேயெல்லாம் NULL மூலம் நிரப்பப்பட்டுவிட்டன. Author அட்டவணையின் Elavarasan முதல் KaviNilavu வரையிலான எழுத்தாளர்களும் இடம்பெற்றிருக்கின்றனர். ஆனால் அவர்கள் எழுதிய புத்தகங்கள் Publication அட்டவணையில் இல்லாத காரணத்தால் வலதுபுறத்தில் NULL இடம்பெற்றுள்ளது. அதேபோல Chicken Special முதல் Making of Nandha வரையிலான நூல்களை எழுதியவர்களின் விபரம் Author அட்டவணையில் இல்லாததால் இடப்பக்கமாக NULL நிரப்பப்பட்டுவிட்டது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />CROSS JOIN பற்றிப் பார்ப்போம்.<br style="margin: 0px; padding: 0px;" />Cross join என்பது குறுக்குப் பெருக்கல் ஆகும்.<br style="margin: 0px; padding: 0px;" />இதன் மாதிரி வடிவம்:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT Author.AuthorName, Publication.BookName, Publication.Publication<br style="margin: 0px; padding: 0px;" />FROM Author CROSS JOIN<br style="margin: 0px; padding: 0px;" />Publication<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />மொத்த rowsன் எண்ணிக்கை = இடப்புறம் உள்ள rowsகளின் எண்ணிக்க x வலப்புறம் உள்ள rows எண்ணிக்கை.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT COUNT(*) FROM Author --&gt; 10 records உள்ளன<br style="margin: 0px; padding: 0px;" />SELECT COUNT(*) FROM Publication --&gt; 16 rows உள்ளன.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Count(*) இந்த Function மூலம் ஒரு tableல் எத்தனை rows உள்ளன என அறியலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Cross join இணைப்பிற்குப் பிறகு உருவாகும்<br style="margin: 0px; padding: 0px;" />rowsகளின் எண்ணிக்கை = 10 x 16 = 160.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இடப்புறமுள்ள ஒவ்வொரு recordம் , வலப்புறமுள்ள அனைத்து recordsஉடன் ஒவ்வொருமுறையும் இணைத்துக் காட்சியளிக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELF JOIN என்பது ஒரே table ஆனது, அதற்குள்ளேயே இணைக்கப்படுவதால் அவ்வாறு அழைக்கப்படுகிறது.&nbsp;</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/2824736612234916602/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-15.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2824736612234916602'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2824736612234916602'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-15.html' title='எளிய தமிழில் SQL - பாகம் 15'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiMv_oQH0IR7QPn635YeptaUyOSW6VcQ_zM7bw6eTB2CIq_TCaHnzIWWnclvnsryQrUEheXBzdqHN5e86LkLNopkjAftY3QEa9TSxdtseKdTzJ4zEkunRlsqlc40n2GL_WCX0uHUuyWmQvH/s72-c/AuthorStructure.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-4522888604367616994</id><published>2013-08-08T04:57:00.000-07:00</published><updated>2013-08-08T04:57:09.851-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 14</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; text-align: justify;">மேலும் SQL க்கான Syntax அட்டவணையை</span><a href="http://www.w3schools.com/sql/sql_quickref.asp" style="color: #2a6080; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;" target="_blank">http://www.w3schools.com/sql/sql_quickref.asp</a><span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; text-align: justify;">&nbsp;</span><span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; text-align: justify;">ல் கண்டேன். அதனைக் கீழே தந்திருக்கிறேன்.</span></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<br style="margin: 0px; padding: 0px;" />நன்றி :&nbsp;<a href="http://www.w3schools.com/" style="color: #2a6080; margin: 0px; padding: 0px;" target="_blank">http://www.w3schools.com</a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த SQL Syntaxகளை நன்றாகப் படித்து மனதில் வைத்துக்கொள்ளவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><table border="1" cellspacing="0" class="ex" style="margin: 0px; padding: 0px; width: 100%px;"><tbody style="margin: 0px; padding: 0px;">
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">AND / OR</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE condition<br style="margin: 0px; padding: 0px;" />AND|OR condition</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">ALTER TABLE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">ALTER TABLE table_name<br style="margin: 0px; padding: 0px;" />ADD column_name datatype<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
or</div>
&nbsp;<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
ALTER TABLE table_name<br style="margin: 0px; padding: 0px;" />DROP COLUMN column_name</div>
</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">AS (alias)</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name AS column_alias<br style="margin: 0px; padding: 0px;" />FROM table_name<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
or</div>
&nbsp;<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
SELECT column_name<br style="margin: 0px; padding: 0px;" />FROM table_name AS table_alias</div>
</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">BETWEEN</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE column_name<br style="margin: 0px; padding: 0px;" />BETWEEN value1 AND value2</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE DATABASE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE DATABASE database_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE TABLE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE TABLE table_name<br style="margin: 0px; padding: 0px;" />(<br style="margin: 0px; padding: 0px;" />column_name1 data_type,<br style="margin: 0px; padding: 0px;" />column_name2 data_type,<br style="margin: 0px; padding: 0px;" />column_name2 data_type,<br style="margin: 0px; padding: 0px;" />...<br style="margin: 0px; padding: 0px;" />)</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE INDEX</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE INDEX index_name<br style="margin: 0px; padding: 0px;" />ON table_name (column_name)<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
or</div>
&nbsp;<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
CREATE UNIQUE INDEX index_name<br style="margin: 0px; padding: 0px;" />ON table_name (column_name)</div>
</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE VIEW</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">CREATE VIEW view_name AS<br style="margin: 0px; padding: 0px;" />SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE condition</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">DELETE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">DELETE FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE some_column=some_value<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
or</div>
&nbsp;<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
DELETE FROM table_name<br style="margin: 0px; padding: 0px;" />(<b style="margin: 0px; padding: 0px;">Note:&nbsp;</b>Deletes the entire table!!)</div>
&nbsp;<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
DELETE * FROM table_name<br style="margin: 0px; padding: 0px;" />(<b style="margin: 0px; padding: 0px;">Note:&nbsp;</b>Deletes the entire table!!)</div>
</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">DROP DATABASE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">DROP DATABASE database_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">DROP INDEX</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">DROP INDEX table_name.index_name (SQL Server)<br style="margin: 0px; padding: 0px;" />DROP INDEX index_name ON table_name (MS Access)<br style="margin: 0px; padding: 0px;" />DROP INDEX index_name (DB2/Oracle)<br style="margin: 0px; padding: 0px;" />ALTER TABLE table_name<br style="margin: 0px; padding: 0px;" />DROP INDEX index_name (MySQL)</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">DROP TABLE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">DROP TABLE table_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">GROUP BY</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name, aggregate_function(column_name)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE column_name operator value<br style="margin: 0px; padding: 0px;" />GROUP BY column_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">HAVING</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name, aggregate_function(column_name)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE column_name operator value<br style="margin: 0px; padding: 0px;" />GROUP BY column_name<br style="margin: 0px; padding: 0px;" />HAVING aggregate_function(column_name) operator value</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">IN</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE column_name<br style="margin: 0px; padding: 0px;" />IN (value1,value2,..)</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">INSERT INTO</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">INSERT INTO table_name<br style="margin: 0px; padding: 0px;" />VALUES (value1, value2, value3,....)<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
<i style="margin: 0px; padding: 0px;">or</i></div>
&nbsp;<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
INSERT INTO table_name<br style="margin: 0px; padding: 0px;" />(column1, column2, column3,...)<br style="margin: 0px; padding: 0px;" />VALUES (value1, value2, value3,....)</div>
</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">INNER JOIN</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name1<br style="margin: 0px; padding: 0px;" />INNER JOIN table_name2<br style="margin: 0px; padding: 0px;" />ON table_name1.column_name=table_name2.column_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">LEFT JOIN</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name1<br style="margin: 0px; padding: 0px;" />LEFT JOIN table_name2<br style="margin: 0px; padding: 0px;" />ON table_name1.column_name=table_name2.column_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">RIGHT JOIN</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name1<br style="margin: 0px; padding: 0px;" />RIGHT JOIN table_name2<br style="margin: 0px; padding: 0px;" />ON table_name1.column_name=table_name2.column_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">FULL JOIN</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name1<br style="margin: 0px; padding: 0px;" />FULL JOIN table_name2<br style="margin: 0px; padding: 0px;" />ON table_name1.column_name=table_name2.column_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">LIKE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE column_name LIKE pattern</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">ORDER BY</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />ORDER BY column_name [ASC|DESC]</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT *</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT *<br style="margin: 0px; padding: 0px;" />FROM table_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT DISTINCT</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT DISTINCT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT INTO</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT *<br style="margin: 0px; padding: 0px;" />INTO new_table_name [IN externaldatabase]<br style="margin: 0px; padding: 0px;" />FROM old_table_name<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
<i style="margin: 0px; padding: 0px;">or</i></div>
&nbsp;<div style="display: inline; height: auto; overflow: visible; padding: 1px 0px;">
SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />INTO new_table_name [IN externaldatabase]<br style="margin: 0px; padding: 0px;" />FROM old_table_name</div>
</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT TOP</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT TOP number|percent column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">TRUNCATE TABLE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">TRUNCATE TABLE table_name</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">UNION</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s) FROM table_name1<br style="margin: 0px; padding: 0px;" />UNION<br style="margin: 0px; padding: 0px;" />SELECT column_name(s) FROM table_name2</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">UNION ALL</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s) FROM table_name1<br style="margin: 0px; padding: 0px;" />UNION ALL<br style="margin: 0px; padding: 0px;" />SELECT column_name(s) FROM table_name2</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">UPDATE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">UPDATE table_name<br style="margin: 0px; padding: 0px;" />SET column1=value, column2=value,...<br style="margin: 0px; padding: 0px;" />WHERE some_column=some_value</td></tr>
<tr style="margin: 0px; padding: 0px;"><td align="left" style="margin: 0px; padding: 0px;" valign="top">WHERE</td><td align="left" style="margin: 0px; padding: 0px;" valign="top">SELECT column_name(s)<br style="margin: 0px; padding: 0px;" />FROM table_name<br style="margin: 0px; padding: 0px;" />WHERE column_name operator value</td></tr>
</tbody></table>
<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Select Statement</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name" FROM "table_name"<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Distinct</span><br style="margin: 0px; padding: 0px;" />SELECT DISTINCT "column_name"<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />Where</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name"<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />WHERE "condition"<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">And/Or</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name"<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />WHERE "simple condition"<br style="margin: 0px; padding: 0px;" />{[AND|OR] "simple condition"}+<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">In</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name"<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />WHERE "column_name" IN ('value1', 'value2', ...)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Between</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name"<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />WHERE "column_name" BETWEEN 'value1' AND 'value2'<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Like</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name"<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />WHERE "column_name" LIKE {PATTERN}<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Order By</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name"<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />[WHERE "condition"]<br style="margin: 0px; padding: 0px;" />ORDER BY "column_name" [ASC, DESC]<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Count</span><br style="margin: 0px; padding: 0px;" />SELECT COUNT("column_name")<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Group By</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name1", SUM("column_name2")<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />GROUP BY "column_name1"<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Having</span><br style="margin: 0px; padding: 0px;" />SELECT "column_name1", SUM("column_name2")<br style="margin: 0px; padding: 0px;" />FROM "table_name"<br style="margin: 0px; padding: 0px;" />GROUP BY "column_name1"<br style="margin: 0px; padding: 0px;" />HAVING (arithematic function condition)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Create Table Statement</span><br style="margin: 0px; padding: 0px;" />CREATE TABLE "table_name"<br style="margin: 0px; padding: 0px;" />("column 1" "data_type_for_column_1",<br style="margin: 0px; padding: 0px;" />"column 2" "data_type_for_column_2",<br style="margin: 0px; padding: 0px;" />... )<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Drop Table Statement</span><br style="margin: 0px; padding: 0px;" />DROP TABLE "table_name"<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Truncate Table Statement</span><br style="margin: 0px; padding: 0px;" />TRUNCATE TABLE "table_name"<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Insert Into Statement</span><br style="margin: 0px; padding: 0px;" />INSERT INTO "table_name" ("column1", "column2", ...)<br style="margin: 0px; padding: 0px;" />VALUES ("value1", "value2", ...)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Update Statement</span><br style="margin: 0px; padding: 0px;" />UPDATE "table_name"<br style="margin: 0px; padding: 0px;" />SET "column_1" = [new value]<br style="margin: 0px; padding: 0px;" />WHERE {condition}<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Delete From Statement</span><br style="margin: 0px; padding: 0px;" />DELETE FROM "table_name"<br style="margin: 0px; padding: 0px;" />WHERE {condition}&nbsp;</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/4522888604367616994/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-14.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4522888604367616994'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4522888604367616994'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-14.html' title='எளிய தமிழில் SQL - பாகம் 14'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-8321700357205211979</id><published>2013-08-08T04:55:00.002-07:00</published><updated>2013-08-08T04:55:22.787-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 13</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<span style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; text-align: justify;">Primary key மற்றும் Foreign key ஆகியவற்றைப் பற்றியும், SQL வாயிலாக இரண்டு Tableகளை இணைப்பது எப்படி என்றும் இன்றைக்குப் பார்ப்போம்.</span><br />
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<br style="margin: 0px; padding: 0px;" />Primary key என்பது ஒரு Tableல் இருக்கும் அனைத்து Row களையும் தனித்தனியாகக் கண்டறிய உதவுகிறது. உதாரணமாக ஒரு எளிய Table. அதில் 2 Columns மட்டும். அவை DirectorID int, DirectorName varchar(50)<br style="margin: 0px; padding: 0px;" />(மேலும் இது Primary keyஆகவும், Autoincrement ஆகவும் கொடுக்கப்படுகிறது. Auto increment என்பது int எனப்படும் எண்களுக்கு மட்டுமே சாத்தியப்படும்) , இந்த Tableக்கு DirectorInfo எனப் பெயரிடுவோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh4l2bxXgnznjQqUl0HRHJuvjB8p612o8YZxIoWiKFlwt1ZlJej87MHHkjA-3fpMVl6Zi6UU9IziCpJ0jHh6vD_wJ70O6XWsPZFg5JRcmOIb1c8LF1kfuZj91KACtDGmewCJahT97snEnrn/s1600-h/DirectorInfoStructure.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298950774897544306" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh4l2bxXgnznjQqUl0HRHJuvjB8p612o8YZxIoWiKFlwt1ZlJej87MHHkjA-3fpMVl6Zi6UU9IziCpJ0jHh6vD_wJ70O6XWsPZFg5JRcmOIb1c8LF1kfuZj91KACtDGmewCJahT97snEnrn/s320/DirectorInfoStructure.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 76px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />இந்த DirectorID எனப்படும் Column ஐ Primary key ஆக மாற்ற என்ன செய்யவேண்டும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />DirectorID எனப்படும் Column ஐத் தேர்வு செய்து Right Click செய்து, தோன்றக்கூடிய சிறு menuவில் Set Primary Key என்பதைச் சொடுக்கவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEizRNmnPoLWXjmooRB6UP-rb6vDiYLQGzQmSrZaSeB2B9-oJzGTSt-G2rnvArk_iNwR-jphblwCHepStcd4dKPWPQ5FCQzBXwirvGqZVezt5-94QjOOwQDolEsmu_s7F5UsrimbY0iXAhlS/s1600-h/setprimary.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298952022178769970" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEizRNmnPoLWXjmooRB6UP-rb6vDiYLQGzQmSrZaSeB2B9-oJzGTSt-G2rnvArk_iNwR-jphblwCHepStcd4dKPWPQ5FCQzBXwirvGqZVezt5-94QjOOwQDolEsmu_s7F5UsrimbY0iXAhlS/s320/setprimary.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 81px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இதைச் செய்தபிறகு DirectorID க்கு இடது புறம் ஒரு சிறிய சாவியின் படம் தெரிய ஆரம்பிக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />மேலும் Identity Column ( Auto increment) ஆக மாற்றுவதற்கு என்ன செய்வது?<br style="margin: 0px; padding: 0px;" />DirectorID எனப்படும் Column ஐத் தேர்வு செய்து F4 என்னும் Function keyஐ அழுத்தினால் Properties Windows ஐக் காணலாம். அதில் Table Designer என்னும் தலைப்பின் கீழே, Identity Column என்பதற்கு நேராக உள்ள Drop Downlist ல் DirectorID என்பதைத் தேர்வு செய்யவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEioTcGtuNa4-BeHIZphmFoilg6fGDVmqICxRmM_0gPSX-gfWVHQzL0FJdGXv0adnx1AWPllx_BR5DJCyqVPTy3MEyi21yLTNY_Jb6g-Kw5Q7vGW57bnqARIH1N1vodwdFqaHpDKpm5nEvz4/s1600-h/identityF4Properties.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298953632193171842" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEioTcGtuNa4-BeHIZphmFoilg6fGDVmqICxRmM_0gPSX-gfWVHQzL0FJdGXv0adnx1AWPllx_BR5DJCyqVPTy3MEyi21yLTNY_Jb6g-Kw5Q7vGW57bnqARIH1N1vodwdFqaHpDKpm5nEvz4/s320/identityF4Properties.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 270px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>அல்லது கீழ்க்கண்ட செயல்முறையைத் தொடரலாம். Identity Column ஆக மாற்ற கீழ்க்கண்ட படத்தில் உள்ளபடி செய்யலாம். அந்த Column ஐத் தேர்வுசெய்தபிறகு, கீழே உள்ள Column Properties Tab ல் , Identity Specification ஐ Yes எனக் கொடுக்கவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhvpwPje7WVIwOQbIJpxb5gQS8DG-F47ekBm0d2oyugE9tWpeodQYIdKiabc2zVNDvtjgdWBOOMaaFitlG1ckzvV0iW_6XIzihdPqesMse1qQsnARh4LPzWo9Qezx0O8ReqPUfwfkZ-aVpV/s1600-h/colProp.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298954575845832306" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhvpwPje7WVIwOQbIJpxb5gQS8DG-F47ekBm0d2oyugE9tWpeodQYIdKiabc2zVNDvtjgdWBOOMaaFitlG1ckzvV0iW_6XIzihdPqesMse1qQsnARh4LPzWo9Qezx0O8ReqPUfwfkZ-aVpV/s320/colProp.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 217px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 252px;" /></a>அதன் Increment , seed மதிப்புகளைக் கொடுக்கலாம். அல்லது 1 எனவே விட்டுவிடலாம். ஒவ்வொரு rowன் மதிப்பும் ஐந்து, ஐந்தாக அதிகரிக்கவேண்டும் எனில் Identity Increment ன் மதிப்பை 5 எனக் கொடுக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />சரி ஒருவழியாக DirectorsInfo வின் Structure ஐ உருவாக்கிவிட்டோம். இப்போது இதை Close செய்துவிடவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi12fbkkzS2cGslBbDuqPGMawFCUlT3JN0Nc777JPVaqhhtzR2-iGYRaE5dwFkz_ytI7Q8OSFd9asrS0PvEasaTrd0Qo6wgsLjCGlhcNERx2eDqSJECaXjU0_Ol1CODCRt-gx6bDr2Q-OT1/s1600-h/closeStructure.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298955974899029762" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi12fbkkzS2cGslBbDuqPGMawFCUlT3JN0Nc777JPVaqhhtzR2-iGYRaE5dwFkz_ytI7Q8OSFd9asrS0PvEasaTrd0Qo6wgsLjCGlhcNERx2eDqSJECaXjU0_Ol1CODCRt-gx6bDr2Q-OT1/s320/closeStructure.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 127px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இப்போது மேலும் ஒரு எளிய Table ஒன்றை உருவாக்கி, அதற்கு FilmInfo எனப் பெயரிடுவோம்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEitWVDGs2oXnig8D0cqALO8vnaLZq7KenHR4Q90rTAITZVjbAYC8dzHiaiQNywP2zWakODBSQSJYNv82o_MI5MBgnAqfxVOJpvdc4FL2ms2Af-jUpNNrG6yDTLCB8uhreuZkIY-gPo4PCT8/s1600-h/FilmInfoStructure.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298956404471710946" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEitWVDGs2oXnig8D0cqALO8vnaLZq7KenHR4Q90rTAITZVjbAYC8dzHiaiQNywP2zWakODBSQSJYNv82o_MI5MBgnAqfxVOJpvdc4FL2ms2Af-jUpNNrG6yDTLCB8uhreuZkIY-gPo4PCT8/s320/FilmInfoStructure.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 120px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 318px;" /></a>இந்த FilmInfo என்கிற புதிய Tableல் DirectorID என்னும் Column உள்ளது. இது int எனப்படும் எண் வகையைச் சேர்ந்த Data Type.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒவ்வொரு படத்தையும் வேறு வேறு இயக்குநர்கள் இயக்கியிருக்கலாம். ஒன்றுக்கு மேற்பட்ட திரைப்படங்களை ஒரே இயக்குநரே இயக்கியிருக்கலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />1000 திரைப்படங்களின் தகவல்களைச் சேகரித்தோம் எனில், அதில் ஒரே இயக்குநரானவர் 10 அல்லது 25 அல்லது 100 படங்களைக்கூட எடுத்திருப்பார். 100 முறை அவரது பெயரை எழுதினால் நினைவகம் (memory) தேவையில்லாமல் ஆக்கிரமிக்கப்படும். அதனால் அவரது பெயரை ஒரே ஒருமுறை மட்டும் Master Table ல் (இங்கே DirectorsInfo - என்பதே Master table) கொடுத்து அவருக்காக ஒரு எண்ணை ஒதுக்கி விடுகிறோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />பலவித திரைப்படங்களின் தகவல்களை இரண்டாவது Table (FilmInfo என்பது இங்கே Detail Table)ல் பதிவுசெய்யப் போகிறோம். இங்கே ஒவ்வொரு Directorன் பெயரை முழுவதும் எழுதி நினைவகத்தை ஆக்கிரமிக்காமல் அவருக்குரிய எண்ணை மட்டும் கொடுப்போம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Master Table ல் ஒவ்வொரு Director க்கும் எண்களும், பெயர்களும் கொடுத்துவிட்டு, Detail Tableல் Directorக்கு உரிய எண்ணை மட்டும் கொடுப்பது வழக்கம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />நினைவக இழப்பைக் குறைப்பதற்காகவும், ஒரே தகவலை திரும்பத்திரும்ப எழுதுவதைத் தவிர்க்கவும் - இந்த ஏற்பாடு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒரு Director ஆனவர் பல படங்களை எடுத்துள்ளார் - எனில் இதை ONE TO MANY RELATIONSHIP என்போம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த இரண்டாவது Tableன் Structureஐ ஏற்றிமுடித்ததும் கீழ்க்கண்ட செயல்முறையைச் செய்து இரண்டு Tableகளுக்கும் ஒரு உறவுமுறையை உண்டாக்கவும். உறவுமுறை (Table Relationship).<br style="margin: 0px; padding: 0px;" />Test எனப்படும் Databaseல் Database Diagrams என்பதைத் தேர்வுசெய்து, Right Click செய்து, அதில் New Database Diagram ஐத் தேர்ந்தெடுக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh62lKzv_VCr8xS2S0mZBvkXoNMzdSYChm3KUwfN0dNOqPpeGIoOJQLbtXb-SY8OmUZ9f3It7zmFBYhOkW0iKwCwjl9fzJEYtU_UtqwkI2n6m3o8OupisiyuebywXm8zPtyGhF9a3bjRs2d/s1600-h/newDBdiag.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298959013592708242" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh62lKzv_VCr8xS2S0mZBvkXoNMzdSYChm3KUwfN0dNOqPpeGIoOJQLbtXb-SY8OmUZ9f3It7zmFBYhOkW0iKwCwjl9fzJEYtU_UtqwkI2n6m3o8OupisiyuebywXm8zPtyGhF9a3bjRs2d/s320/newDBdiag.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 104px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 312px;" /></a><br style="margin: 0px; padding: 0px;" />உடன் தெரியும் உரையாடல் பெட்டியில் (dialog box) , DirectorsInfo மற்றும், FilmInfo ஆகிய இரண்டு Tableகளையும் தேர்வு செய்து , Add ஐ அழுத்தியபிறகு, Close அழுத்தவும்.<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEieNqDuj0zZ6ljf0pk_DKgZ3hQQpEw4NlAo33eEprUOIGSklUXcihRRRKn5Ns3oH5_T5sjZc8OzOyvs5f2H_G3_2hU3yiAXXX3SGQCY3ugutpouAvoxB9OIanB4fVDPyPPF85_SO4cfvaWZ/s1600-h/setrelation.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298960463081737314" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEieNqDuj0zZ6ljf0pk_DKgZ3hQQpEw4NlAo33eEprUOIGSklUXcihRRRKn5Ns3oH5_T5sjZc8OzOyvs5f2H_G3_2hU3yiAXXX3SGQCY3ugutpouAvoxB9OIanB4fVDPyPPF85_SO4cfvaWZ/s320/setrelation.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 251px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இப்போது திரை கீழ்க்கண்டவாறு காட்சியளிக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiLXjXwI80qx8o5uwR2b7GBgNnm6nMh73XD1lkXXJHq2ctrRtyveurU2CFeYv_D3-zZQiEvITyfqRaLa_Rm1X1o3o8HowxfBh2kikKaGj1sbEoTctyjOB3-oompeSbbXbACSkWTVImkLlPk/s1600-h/beforejoin.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298961613327038002" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiLXjXwI80qx8o5uwR2b7GBgNnm6nMh73XD1lkXXJHq2ctrRtyveurU2CFeYv_D3-zZQiEvITyfqRaLa_Rm1X1o3o8HowxfBh2kikKaGj1sbEoTctyjOB3-oompeSbbXbACSkWTVImkLlPk/s320/beforejoin.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 106px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>DirectorsInfo ல் இருக்கும் DirectorID ஐ அப்படியே இழுத்துக்கொண்டு வந்து, FilmInfo வில் இருக்கும் DirectorIDல் விடவும். அதாவது Master Tableன் DirectorID ஐ Drag செய்து, Detail Table ல் இருக்கும் DirectorIDல் Drop செய்யவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எளிதான Drag and Drop தான்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgXLPAQgbFEdVMMliuXe68xxYrZd_RBvBoCjsvgA-XPlGxssZtF_hQYIVv7s4o57pP9SGqpt9vZFcZgrW9hKwjiWnX1_LYTrOG8ZqW2XatpBeoS9ixFjIYVnTersSNSVrVidLcGRJpBejdq/s1600-h/merge.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298962340161039874" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgXLPAQgbFEdVMMliuXe68xxYrZd_RBvBoCjsvgA-XPlGxssZtF_hQYIVv7s4o57pP9SGqpt9vZFcZgrW9hKwjiWnX1_LYTrOG8ZqW2XatpBeoS9ixFjIYVnTersSNSVrVidLcGRJpBejdq/s320/merge.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 94px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />இப்போது திரையில் மேற்கண்ட படம் தெரியும். Primary key Table (Director Info).<br style="margin: 0px; padding: 0px;" />Foreign Key Table (FilmInfo). இரண்டுமே DirectorID என்னும் Column ஆகவும், ஒரே DataTypeஆகவும் இருக்கிறது. பிறகு இரண்டு முறை OK கொடுக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது திரையில் கீழ்க்கண்ட படத்தைக் காணலாம்.<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhUbpiQ1Xq8dVHU3vRwZ2fFujtYRaiYmRYvsip9cN-aVVHvOGvYkOGfLMnVVTvbv_N9T6d4VimuHgUcz41QyF3bimyllM2-TPGFFxZfIpyrDjXoESi0P3R42EXHO2bmQxfgtNwMZx3-HdPh/s1600-h/afterrelation.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298962966167548258" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhUbpiQ1Xq8dVHU3vRwZ2fFujtYRaiYmRYvsip9cN-aVVHvOGvYkOGfLMnVVTvbv_N9T6d4VimuHgUcz41QyF3bimyllM2-TPGFFxZfIpyrDjXoESi0P3R42EXHO2bmQxfgtNwMZx3-HdPh/s320/afterrelation.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 130px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இந்த Database Diagram ஐ Close செய்துவிட்டு, Tableக்குரிய தகவல்களை ஒவ்வொரு Row ஆக ஏற்றவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />DirectorsInfo வில் முதலில் உங்களுக்குத் தெரிந்த Directorsன் பெயர்களை மட்டும் கொடுத்தால் போதும். DirectorID என்பது அதுவாகவே உருவாகிக்கொள்ளும். அடுத்தடுத்த Directorகளுக்குரிய எண்கள் தானாகவே அமைந்துகொள்ளும். இதற்கு காரணம் அந்த குறிப்பிட்ட Column ஆனது IDENTITY Column என அமைக்கப்பட்டுள்ளதே.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />பிறகு ஒவ்வொரு படங்களுக்கும் உரிய தகவல்களை Row by Row வாக FilmInfo என்னும் Tableல் ஏற்றவும். இங்கே DirectorIDஎன்னும் Columnல் ஏற்கனவே Master Tableல் என்ன எண்கள் அளிக்கப்பட்டிருக்கிறதோ அவற்றை மாத்திரமே கொடுக்கவேண்டும். Master Tableல் இல்லாத DirectorID ஐக் கொடுத்தால் பிழைச்செய்தி காண்பிக்கும்.<br style="margin: 0px; padding: 0px;" />உதாரணத்திற்காக DirectorInfoவில் சில records உங்கள் பார்வைக்கு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgJzf2Vw_y0LAu0z3AowHBM7-m9gbhVkBcKuG8MTa_1ngth7bIa5SneSllP173TtshsrYCAPi3UehkYoZ6UFdRzvtcicjY7mN7deVnTW6la8vACfZs8_wxkhrz6W-YrFKbU1g4OZhY9u3Ak/s1600-h/DirectorInfo.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298964561414444882" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgJzf2Vw_y0LAu0z3AowHBM7-m9gbhVkBcKuG8MTa_1ngth7bIa5SneSllP173TtshsrYCAPi3UehkYoZ6UFdRzvtcicjY7mN7deVnTW6la8vACfZs8_wxkhrz6W-YrFKbU1g4OZhY9u3Ak/s320/DirectorInfo.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 122px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 241px;" /></a>FilmInfo எனப்படும் Detail Tableல் நான் ஏற்றிய சில Records கீழே.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjyj8YBERvz4H4KJ5sxpOXqkH8XASTQll8jW4GphtOgVVNs301QGiyVqiEfoGTgGoXMtl3adMYKLtv5uKb5CNCTP8ng_nD7xDRNyKIKalub8J6EzxO9FmXoQFu0EqpQaDaTYalBZZjQXUqB/s1600-h/sampledetails.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298966452228445794" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjyj8YBERvz4H4KJ5sxpOXqkH8XASTQll8jW4GphtOgVVNs301QGiyVqiEfoGTgGoXMtl3adMYKLtv5uKb5CNCTP8ng_nD7xDRNyKIKalub8J6EzxO9FmXoQFu0EqpQaDaTYalBZZjQXUqB/s320/sampledetails.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 165px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இதில் Master Table ல் என்ன DirectorID கொடுத்தோமோ அதை Detail Tableல் refer செய்கிறோம். ஒவ்வொரு படத்துக்கும் அதை இயக்கிய இயக்குநரின் பெயரைக் கொடுக்காமல், அவருக்குரிய ID எனப்படும் எண்ணை மட்டும் கொடுக்கிறோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இரண்டு Tableஐயும் இணைத்து JOIN செய்வதற்கு உரிய செயல்முறை கீழே:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />T-SQL Editorல் Right Click செய்து, Design Query in Editor என்பதைத் தேர்வு செய்யவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg5o4FHEOJW3Jm_AFhCXyh62LmbM6QrvnC5GVNJyBoYGmeJ4AvPgcQSO-rboBlsinblKuqRozKsjK317xeXpIwuZBQ8cRHmLB-FlzNObsIp4mIDirrGJgr-Aha0OobFzCHIhnbPr3g2LN13/s1600-h/designqueryeditor.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298967552670741682" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg5o4FHEOJW3Jm_AFhCXyh62LmbM6QrvnC5GVNJyBoYGmeJ4AvPgcQSO-rboBlsinblKuqRozKsjK317xeXpIwuZBQ8cRHmLB-FlzNObsIp4mIDirrGJgr-Aha0OobFzCHIhnbPr3g2LN13/s320/designqueryeditor.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 293px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />பிறகு வரும் Dialog boxல் இரண்டு Tablesஐயும் தேர்வு செய்து Add கொடுத்தபின் Close செய்யவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi-fjknZ-OoyUxfrfYVk9nn7nITjk75j-MEu69nVrsSBsyUB3qR3npDMQRnA4PAB93q_Yf_t1yk0pnzf9tUoqtQ5cYejCUjkDkMbJ__-m7RX4oWekwL7o5MUJOKCLVohXG9b6gLkOVPdQBo/s1600-h/add2tables.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298967976309837490" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi-fjknZ-OoyUxfrfYVk9nn7nITjk75j-MEu69nVrsSBsyUB3qR3npDMQRnA4PAB93q_Yf_t1yk0pnzf9tUoqtQ5cYejCUjkDkMbJ__-m7RX4oWekwL7o5MUJOKCLVohXG9b6gLkOVPdQBo/s320/add2tables.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 249px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>ஏற்கனவே Primary key, மற்றும் Foreign key ஆகியவை முறைப்படி இணைக்கப்பட்டிருந்தால் கீழ்க்கண்ட படம் திரையில் காட்சியளிக்கும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjrIUGUmvuO7Z9X3IFsb3WAGewcOJNNqXG55GboOJW5GAyHvzDUCCHgwuJX3tWHDz5w3uTS1nAWnvzgXJ7uljx2A8D3bB76XglJnqG7zvIXSQmXtZiSeoVFoG_-uhYrRVcH8BENpkvRAhbF/s1600-h/screen.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298968422351045666" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjrIUGUmvuO7Z9X3IFsb3WAGewcOJNNqXG55GboOJW5GAyHvzDUCCHgwuJX3tWHDz5w3uTS1nAWnvzgXJ7uljx2A8D3bB76XglJnqG7zvIXSQmXtZiSeoVFoG_-uhYrRVcH8BENpkvRAhbF/s320/screen.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 109px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இரண்டு Tableகளிலிருந்து எந்தெந்த Columnsஐ நாம் தேர்ந்தெடுக்கிறோம் என்பதை ஒவ்வொரு Columnக்கும் எதிரேயுள்ள Checkbox ல் Tick செய்துவிடுங்கள்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi8rbdcUGGHJRu5c8oQwA-6sNus258br2C6exEyC7HGG44Ey-O6uRcN8u1q3MBnY-UVXbOUMbzekJ5X0jJhdl8Go9Y59ARNwY00NEjQQ_0pDJxefgEX26PmFzBDPNKg9B42-pMWhn-lGFJC/s1600-h/fieldselection.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298969314509893890" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi8rbdcUGGHJRu5c8oQwA-6sNus258br2C6exEyC7HGG44Ey-O6uRcN8u1q3MBnY-UVXbOUMbzekJ5X0jJhdl8Go9Y59ARNwY00NEjQQ_0pDJxefgEX26PmFzBDPNKg9B42-pMWhn-lGFJC/s320/fieldselection.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 138px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இப்படி Columnகளைத் தேர்வுசெய்தவுடன் உங்களுக்குக் கீழ்க்கண்ட Query கிடைக்கும்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT DirectorsInfo.DirectorName, FilmInfo.FilmName, FilmInfo.Actor, FilmInfo.Actress<br style="margin: 0px; padding: 0px;" />FROM DirectorsInfo INNER JOIN<br style="margin: 0px; padding: 0px;" />FilmInfo ON DirectorsInfo.DirectorID = FilmInfo.DirectorID<br style="margin: 0px; padding: 0px;" />பின் OK அழுத்தினால் மேலேயுள்ள Query ஆனது T-SQL Editorக்கு வந்துவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />F5 அழுத்தின் இயக்கவும். இதன் மூலம் இரண்டு Tableன் தகவல்களும் ஒரே திரையில் காண்பிக்கப்படும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhvsOsbVhbSwmRj7TOvhl73_nV7uwoRtaCOlOLl9I3fKZnJQqQL9rShJkd9GkLIknWHT3Z2B2pdPajPmeLt9ZQ7zW9GgVpKoECwhreC1iHFkDv7hHNQ91unkWYQt_mCYYG29rE6SUswcuos/s1600-h/aftermerge.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298969994592783138" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhvsOsbVhbSwmRj7TOvhl73_nV7uwoRtaCOlOLl9I3fKZnJQqQL9rShJkd9GkLIknWHT3Z2B2pdPajPmeLt9ZQ7zW9GgVpKoECwhreC1iHFkDv7hHNQ91unkWYQt_mCYYG29rE6SUswcuos/s320/aftermerge.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 191px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a></div>
<div>
<br /></div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/8321700357205211979/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-13.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/8321700357205211979'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/8321700357205211979'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-13.html' title='எளிய தமிழில் SQL - பாகம் 13'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh4l2bxXgnznjQqUl0HRHJuvjB8p612o8YZxIoWiKFlwt1ZlJej87MHHkjA-3fpMVl6Zi6UU9IziCpJ0jHh6vD_wJ70O6XWsPZFg5JRcmOIb1c8LF1kfuZj91KACtDGmewCJahT97snEnrn/s72-c/DirectorInfoStructure.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-2582656357476967516</id><published>2013-08-08T04:54:00.005-07:00</published><updated>2013-08-08T04:54:51.876-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 12</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<span style="color: #009900; font-family: Georgia, Times, serif; font-size: 13px; font-weight: bold; line-height: 20.984375px; text-align: center;">SELECT உடன் ஒரு செயல்முறைப் பயிற்சி</span></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM tableName</span>&nbsp;என்பது ஒரு Tableல் இருக்கும் அனைத்து Rowsஐயும் திரையில் காண்பிக்க, தேடி எடுக்க.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதில் குறிப்பிட்ட Rowsஐ மாத்திரம் எடுப்பதற்கு என்ன செய்யவேண்டும். ஒரு WHERE ஐ இணைத்தால் போதும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM tableName WHERE Condition</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Condition என்பதைக் கட்டுப்பாடு எனக் கொண்டால் ஒன்றுக்கு மேற்பட்ட கட்டுப்பாடுகளை விதிக்க என்ன செய்ய வேண்டும்?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM tableName WHERE Condition1 AND Condition2 AND Condition3</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />AND என்னும் Logical Operator ஐ உடன் சேர்த்துப் பயன்படுத்த வேண்டும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT * FROM என்று கொடுத்தால் அனைத்து Columns ஐயும் நாம் பார்ப்பதற்காக தேர்வு செய்கிறோம் என்று அர்த்தம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதில் குறிப்பிட்ட Columnsஐ மாத்திரம் பார்க்கவேண்டுமென்றால் என்ன செய்வது?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT Column1, Column2, Column3 FROM tableName<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT column_name(s) FROM table_name<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உதாரணம்:<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT [Name], [City] FROM Persons</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />கீழ்க்கண்ட Tableன் தகவல்களை உற்று நோக்கவும். இதில் City என்னும் இடத்தில் 3 நகரங்கள் உள்ளன. Chennai, Erode, USA. ஆனால் Chennai,Erode ஆகியவை இரண்டுமுறையும், USA - ஒருமுறையும் இடம் பெற்றுள்ளது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEik6Z3X7-9V8d4B3bHXAZb9veCmhq8uJYRaohm1E4ggVXHYJ2SZDC42jMfLgXZzmUQp_Z4n7eb_Nq761fzfa04UV9duIdcVGgxVA-ZPELUcK2gXo2YImNMoT6HyY1eZuWthMf27TTqTiQGF/s320/allcaps.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEik6Z3X7-9V8d4B3bHXAZb9veCmhq8uJYRaohm1E4ggVXHYJ2SZDC42jMfLgXZzmUQp_Z4n7eb_Nq761fzfa04UV9duIdcVGgxVA-ZPELUcK2gXo2YImNMoT6HyY1eZuWthMf27TTqTiQGF/s320/allcaps.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 139px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 206px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><pre style="padding: 0px;"><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT [CITY] FROM MyList </span>எனக் கொடுத்தால் அனைத்து நகரங்களும் வரும்.</pre>
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjHjF4_RqzX_rDGd9wwN_fC26wlQ019Fx1qQ1_CSVYISBu5Y6XbNNZ5XCaXxQG4XkquPYqmfR3Gxwpn-st5jdDBMiqjnkT5dqtUaaoJ4SpFa1JcePR6b_y_wa_6d5LdFnbgpIFNIEX8PvHQ/s1600-h/allcities.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298611794545466642" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjHjF4_RqzX_rDGd9wwN_fC26wlQ019Fx1qQ1_CSVYISBu5Y6XbNNZ5XCaXxQG4XkquPYqmfR3Gxwpn-st5jdDBMiqjnkT5dqtUaaoJ4SpFa1JcePR6b_y_wa_6d5LdFnbgpIFNIEX8PvHQ/s320/allcities.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 113px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 87px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஆனால் இதில் திரும்பத்திரும்ப வரும் நகரங்களை விட்டுவிட்டு, ஒன்றுக்கு மேற்பட்டு வந்திருப்பவைகளை ஒரே ஒரு முறை மட்டும் காண்பிப்பதற்கு DISTINCT உதவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT DISTINCT [CITY] FROM MyList</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjJTXcGqRi1BSPiIMyKrPMqfOjbaL36YoaguuVdbfgPb1GsSw1D34_rSn5ChnegvN1Wob2HNw57CyuSc6se8vbDmrYhKHEA59RX0w7Aca46tuAswDgO2PkbisRwPEElkXNrwN6Uu-7tCpha/s1600-h/distinctcities.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298612289794092290" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjJTXcGqRi1BSPiIMyKrPMqfOjbaL36YoaguuVdbfgPb1GsSw1D34_rSn5ChnegvN1Wob2HNw57CyuSc6se8vbDmrYhKHEA59RX0w7Aca46tuAswDgO2PkbisRwPEElkXNrwN6Uu-7tCpha/s320/distinctcities.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 74px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 87px;" /></a>குறிப்பிட்ட நகரத்தை மட்டும் காண்பதற்கு இதில் WHERE பயன்படுத்துவோம்.<br style="margin: 0px; padding: 0px;" /><pre style="padding: 0px;">SELECT column_name(s)
FROM table_name
WHERE column_name operator value
<span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE City ='Erode'</span>
ஈரோடு நகர் நண்பர்களைப் பற்றி மட்டும் காண்பதற்கு
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiI_xOixWtwYCEjFGpkkojkqJ07f5KXGZ97tzowm44eEzMpruA7ttFxYxuNI9s3P26G-PC4j0qK76Eo_doNyhyphenhyphenST3Qia50sNQ_8Qbi2uHde3BV1odofYay-16j7yWlmFAniUdilKxaHeM8x/s1600-h/erodeonly.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298613016990427378" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiI_xOixWtwYCEjFGpkkojkqJ07f5KXGZ97tzowm44eEzMpruA7ttFxYxuNI9s3P26G-PC4j0qK76Eo_doNyhyphenhyphenST3Qia50sNQ_8Qbi2uHde3BV1odofYay-16j7yWlmFAniUdilKxaHeM8x/s320/erodeonly.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 57px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 186px;" /></a>நமது தேர்வில் ஒன்றுக்குமேற்பட்ட நகரத்தைக் காண்பதற்கு OR பயன்படுத்துவோம்
அமெரிக்கா மற்றும், சென்னை - இவற்றைத் தேர்வு செய்வதற்கு :
<span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE City ='USA' OR City = 'Chennai'</span>
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiQxC3JApj4ZodQxGIX7OfGgMpNYjd3oH5OiyTC5Y1r2Sba_TLw3AlyNG6kHVmV3iddoRBrq7Oqu6NCJKEUqURzSWONGQXBew1noBIck9X4irmUdCyl3ejwP92I0lc1zZtOYa7QNaIjnsYG/s1600-h/usawithchennai.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298613544481232978" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiQxC3JApj4ZodQxGIX7OfGgMpNYjd3oH5OiyTC5Y1r2Sba_TLw3AlyNG6kHVmV3iddoRBrq7Oqu6NCJKEUqURzSWONGQXBew1noBIck9X4irmUdCyl3ejwP92I0lc1zZtOYa7QNaIjnsYG/s320/usawithchennai.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 77px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 190px;" /></a></pre>
இதையே வேறு விதமாக OR பயன்படுத்தாமல் எழுதலாம். அதற்கு IN பயன்படுத்தவேண்டும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE City IN ('USA' ,'Chennai')</span><br style="margin: 0px; padding: 0px;" />இதற்கும் அதே விடைதான்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />சென்னை நீங்கலாக உள்ள நகரங்களில் இருக்கும் நண்பர்களின் பட்டியலைப் பார்வையிட:<br style="margin: 0px; padding: 0px;" />இதற்கு NOT பயன்படுத்தலாம். NOT என்பது Logical Operator வகையைச் சார்ந்தது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />&lt;&gt; , != என்பது Relational Operator வகையைச் சேர்ந்தது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">அ) SELECT * FROM MyList WHERE City &lt;&gt; 'Chennai'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">ஆ) SELECT * FROM MyList WHERE City != 'Chennai'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">இ) SELECT * FROM MyList WHERE City NOT IN ('Chennai')</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அனைத்துக்கும் ஒரே விடைதான். அது கீழே. சென்னையைத் தவிர.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjYZU66IZQdELcYzdhz9r7-MyfDS-W9GwL0uDF8Ikffo3pAP0R1tZA9IhT9_R2VMBaxjxxS7XDs2Ad4LXzpvS-zdn9ARDznoLm7V4OSfJ2K7XEEok4-FB0yNpPT28WiB-RV4WMK3vTlBhrN/s1600-h/exceptchennai.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298614827431198242" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjYZU66IZQdELcYzdhz9r7-MyfDS-W9GwL0uDF8Ikffo3pAP0R1tZA9IhT9_R2VMBaxjxxS7XDs2Ad4LXzpvS-zdn9ARDznoLm7V4OSfJ2K7XEEok4-FB0yNpPT28WiB-RV4WMK3vTlBhrN/s320/exceptchennai.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 76px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 185px;" /></a>யாருடைய பெயரில் n என்கிற எழுத்து உள்ளது என்பதை அறிவதற்கு :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Name] LIKE '%n%'</span><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhiSNgo7VqSMN5MqSBK5zugk58gMF7V2ZmA1cJ50HeXMa72yn3ih-XLwt4g4-vfAfezuJY6p1T70ZazlbDcpG20R4YJnzQmUTLtF1rpkFcsUfhOwvahdUyPPQZbpY_UNUoEc8q6oBskxj02/s1600-h/insideN.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298615690564414738" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhiSNgo7VqSMN5MqSBK5zugk58gMF7V2ZmA1cJ50HeXMa72yn3ih-XLwt4g4-vfAfezuJY6p1T70ZazlbDcpG20R4YJnzQmUTLtF1rpkFcsUfhOwvahdUyPPQZbpY_UNUoEc8q6oBskxj02/s320/insideN.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 58px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 197px;" /></a>LIKE எனப்படும் keywordன் பயன் யாதெனில், குறிப்பிட்ட எழுத்துகளைக் கொண்ட தகவல்களை மட்டும் தேர்வு செய்வது<br style="margin: 0px; padding: 0px;" />%n% எனில் ஏதோ ஒரு எழுத்து n ஆக இருக்கும் நபர்கள்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />_ என்பது&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">underscore&nbsp;</span>(அடிக்கோடு), இது ஒரு எழுத்தை மட்டும் எதைக்கொண்டாவது நிரப்பிக்கொள் என்பதற்காக. % என்பது மீதமுள்ள அனைத்து எழுத்துக்களையும் நிரப்பிக்கொள் என்பதே. இவற்றிற்கு Wild Card Characters என்று பெயர்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Name] LIKE '_a%'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />முதல் எழுத்து எதுவாக இருந்தாலும் பரவாயில்லை. ஆனால் இரண்டாம் எழுத்து கண்டிப்பாக 'a'. மீதியுள்ள எழுத்துக்களைப் பற்றிக் கவலையில்லை. அதற்காக.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />சுருங்கச் சொன்னால் யாருடைய பெயரில், இரண்டாம் எழுத்து a ஆக இருக்கிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><pre style="padding: 0px;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiI_xOixWtwYCEjFGpkkojkqJ07f5KXGZ97tzowm44eEzMpruA7ttFxYxuNI9s3P26G-PC4j0qK76Eo_doNyhyphenhyphenST3Qia50sNQ_8Qbi2uHde3BV1odofYay-16j7yWlmFAniUdilKxaHeM8x/s1600-h/erodeonly.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298613016990427378" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiI_xOixWtwYCEjFGpkkojkqJ07f5KXGZ97tzowm44eEzMpruA7ttFxYxuNI9s3P26G-PC4j0qK76Eo_doNyhyphenhyphenST3Qia50sNQ_8Qbi2uHde3BV1odofYay-16j7yWlmFAniUdilKxaHeM8x/s320/erodeonly.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 57px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 186px;" /></a></pre>
Person# ல் 1,3,5 ஆகியோர்களைத் தேர்வு செய்வதற்கு:<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Person#] = 1 OR [Person#] = 2 OR [Person#] = 3</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjIm-BqB2FfF7UCo97wetv5aZnvAaPW4m0r0n97Ao9VBlD0qY0JiR_jSdsDyEt9S8osxYN9nbQAZKvea_swUc9O2WUUaOtMHnyh8lQo9QNCrYEbP-6NzKfwPGYWEBOYUGVLezvUEg1fqTGP/s1600-h/135.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298618264684684818" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjIm-BqB2FfF7UCo97wetv5aZnvAaPW4m0r0n97Ao9VBlD0qY0JiR_jSdsDyEt9S8osxYN9nbQAZKvea_swUc9O2WUUaOtMHnyh8lQo9QNCrYEbP-6NzKfwPGYWEBOYUGVLezvUEg1fqTGP/s320/135.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 75px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 153px;" /></a>OR என்பது எதாவது ஒரு Condition ஏற்றுக்கொண்டாலும் ஒத்துழைக்கக்கூடியது<br style="margin: 0px; padding: 0px;" />இதை IN மூலம் எழுதினால்,<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Person#] IN (1,3,5)</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />1,3,5 இவற்றைத் தவிர பிற Rowsகளைப் பார்க்க :<br style="margin: 0px; padding: 0px;" />அதாவது 2, மற்றும் 4 ஆகியவற்றை மட்டும் பார்க்க<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Person#] NOT IN (1,3,5)</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அல்லது<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Person#] != 1 AND [Person#] != 3 AND [Person#] !=5</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அல்லது<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Person#] &lt;&gt; 1 AND [Person#] &lt;&gt; 3 AND [Person#] &lt;&gt; 5</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgk_QCi37bBOOAODrNjQwexGwBH_wMXG2tvPkqqfPs0lxF630ZVdH9VZS83NUJh5MpwP7Js2wlI-1HS-7JZxIDq8_-Rw_7Ts9GW1OYzymr6qWgpExXlWfAJgFdJJdkS4BCWKcQIePfIYwBE/s1600-h/24.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298618900580010754" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgk_QCi37bBOOAODrNjQwexGwBH_wMXG2tvPkqqfPs0lxF630ZVdH9VZS83NUJh5MpwP7Js2wlI-1HS-7JZxIDq8_-Rw_7Ts9GW1OYzymr6qWgpExXlWfAJgFdJJdkS4BCWKcQIePfIYwBE/s320/24.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 57px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 169px;" /></a>SELECT * FROM MyList எனக் கொடுக்கிறேன்.<br style="margin: 0px; padding: 0px;" />இதன் விடை<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiMVqlH2Z9HyZ0UszRFSy69ilH_O1ccg_WoJw_dbFTLuzQghHSR2LgoZD5UEA2RL9ZGDn2MBbr7X-63cn18TOpZ9ofImdIjA2RQIupyOzmXS2RUb5PzRpLHJGKSiz0qVNlTUDTJKLDbsmtT/s1600-h/allstar.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298620304375675778" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiMVqlH2Z9HyZ0UszRFSy69ilH_O1ccg_WoJw_dbFTLuzQghHSR2LgoZD5UEA2RL9ZGDn2MBbr7X-63cn18TOpZ9ofImdIjA2RQIupyOzmXS2RUb5PzRpLHJGKSiz0qVNlTUDTJKLDbsmtT/s320/allstar.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 119px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 199px;" /></a>இதில் பெயர்களை மையமாகக் கொண்டு ஏறுவரிசை (ascending), அல்லது இறங்குவரிசை (descending) ஆகக் காண்பிப்பதற்கு என்ன செய்வது?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதற்காக SELECT உடன் ORDER BY எனப்படும் keyword ஐப் பயன்படுத்தவேண்டும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ASC எனக் கொடுத்தால் ஏறுவரிசையாகவும், DESC எனக் கொடுத்தால் இறங்குவரிசையாகவும் காட்சியளிக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList ORDER BY [Name] ASC</span>&nbsp;(ஏறுவரிசையில் பார்க்க)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEizJxvTUlCbvx9KNdNrbvCm7DMpkGW9x-3KWtoHMuIPkG5akaM_uvR1OPMwaGX2sZZTNedpUG4YSGXaGx58YAn5lhMj5Ws7EVaDTz51O2UTpaZi5kud0h_vKOR28kvBkpqNKs5t8WwVq0bH/s1600-h/ASC.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298620703333580834" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEizJxvTUlCbvx9KNdNrbvCm7DMpkGW9x-3KWtoHMuIPkG5akaM_uvR1OPMwaGX2sZZTNedpUG4YSGXaGx58YAn5lhMj5Ws7EVaDTz51O2UTpaZi5kud0h_vKOR28kvBkpqNKs5t8WwVq0bH/s320/ASC.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 112px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 165px;" /></a><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList ORDER BY [Name] DESC</span>&nbsp;(இறங்குவரிசையில் காண)<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhLv7Da_Op_I5-2ePAfxpUxH2qeM5fr5YcIaW0I7weWMnTE36vbZ7Q7S1iDJOh6oKwiENx07aFTWmfVhBtAf-2E8o2jg3nsT6wUchXkk2YAs6E702TVbndM7iOsnQ0sjUtdjIkpgZg9IRcY/s1600-h/desc.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298621144229844738" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhLv7Da_Op_I5-2ePAfxpUxH2qeM5fr5YcIaW0I7weWMnTE36vbZ7Q7S1iDJOh6oKwiENx07aFTWmfVhBtAf-2E8o2jg3nsT6wUchXkk2YAs6E702TVbndM7iOsnQ0sjUtdjIkpgZg9IRcY/s320/desc.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 114px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 167px;" /></a></div>
<div>
<br /></div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/2582656357476967516/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-12.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2582656357476967516'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2582656357476967516'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-12.html' title='எளிய தமிழில் SQL - பாகம் 12'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEik6Z3X7-9V8d4B3bHXAZb9veCmhq8uJYRaohm1E4ggVXHYJ2SZDC42jMfLgXZzmUQp_Z4n7eb_Nq761fzfa04UV9duIdcVGgxVA-ZPELUcK2gXo2YImNMoT6HyY1eZuWthMf27TTqTiQGF/s72-c/allcaps.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-433959291756216337</id><published>2013-08-08T04:54:00.002-07:00</published><updated>2013-08-08T04:54:21.044-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 11</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px;">இன்று ஒரு சிறிய செயல்முறைப் பயிற்சியை மேற்கொள்வோம். இதற்காக நாம் ஒரு புதிய Tableஐ உருவாக்குவோம். அதற்குரிய Structure கீழே :</span></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<div dir="ltr" style="margin: 0px; padding: 0px; text-align: left;" trbidi="on">
<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhXCrsCxI-gMGczd67jxmnMOFQyFzwGudmz3jwxoUlAFAyRp93lB-QxgHxfMMVZRDZNq3pQcu9SbfR2F9FwLkeu36lEvJMMYa3onPLICBWuhQ7Hk3tJd2Ma7i5QajjRjQUcEaU-WCcX1t1s/s1600-h/structureMarks.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298202671317355170" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhXCrsCxI-gMGczd67jxmnMOFQyFzwGudmz3jwxoUlAFAyRp93lB-QxgHxfMMVZRDZNq3pQcu9SbfR2F9FwLkeu36lEvJMMYa3onPLICBWuhQ7Hk3tJd2Ma7i5QajjRjQUcEaU-WCcX1t1s/s320/structureMarks.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 174px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இந்தப் படத்தில் RegNoக்குறிய Columnல் Primary key க்கான படம் சிறிய சாவியாகக் குறிக்கப்பட்டுள்ளது. ஒரு Column ஐ Primary key ஆக எப்படி மாற்றுவது?<br style="margin: 0px; padding: 0px;" />அந்தக் குறிப்பிட்ட Columnஐத் தேர்வு செய்யவும். பிறகு Right Click செய்து, வரக்கூடிய சிறிய menu வில் Set Primary key எனக் கொடுக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhWBB1SXFm-OStSgLjEwILru8uL9RvyQFztFL3VriagwA6ihfZ9uo591m-QFRy3F2Wnm_ZpG8awixgEG-g9SvE7UKwa6WSvGZbgh0i3IUHOPDnOp1ZlIVHrZr6GSHupNxZZDnromQNN5CWW/s1600-h/setprimarykey.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298203787738279666" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhWBB1SXFm-OStSgLjEwILru8uL9RvyQFztFL3VriagwA6ihfZ9uo591m-QFRy3F2Wnm_ZpG8awixgEG-g9SvE7UKwa6WSvGZbgh0i3IUHOPDnOp1ZlIVHrZr6GSHupNxZZDnromQNN5CWW/s320/setprimarykey.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 90px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />அவ்வளவுதான் Columnஐ, Primary key எனக் குறித்தாயிற்று. அதனால் ஒவ்வொரு நபருக்கும் நாம் கொடுக்கவேண்டிய பதிவு எண் (Registration Number)ணை மாற்றி, மாற்றிக் கொடுக்கவேண்டும். ஒரு நபருக்குக் கொடுத்த எண்ணையே மற்றோர் நபருக்குத் திரும்பவும் கொடுத்தால் பிழைச்செய்தி வரும். ஒவ்வொரு Rowன் RegNo ஐயும் வித்தியாசப்படுத்தவே Primary key ஐத் தேர்வுசெய்கிறோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgYBPxghyphenhyphenCuf0s9loQPpy1UzKc3cQSpi97oZEo1U0bgrhufiszAhWQvtnk3qeUNjJcuIDX_T7oTd-yTJeOkVkr-g1mT0Bsshx00R_lQhQO-OUp-X5eYXzOY38fwf3iY2S8fbUBhWaBDGSJS/s1600-h/Close.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298204780998698194" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgYBPxghyphenhyphenCuf0s9loQPpy1UzKc3cQSpi97oZEo1U0bgrhufiszAhWQvtnk3qeUNjJcuIDX_T7oTd-yTJeOkVkr-g1mT0Bsshx00R_lQhQO-OUp-X5eYXzOY38fwf3iY2S8fbUBhWaBDGSJS/s320/Close.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 118px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />Table Structureஐ Close செய்துவிட்டு, ஒரு Table Name கொடுத்துப் பதிவு செய்கிறோம். (MarkStatement என்று பெயர்கொடுத்திருக்கிறேன்). நினைவகத்தில் வன்வட்டு (hard disk)ல் பதிவாகிவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதில் Total, Average, Result ஆகிய Columnளுக்கு மட்டும் Allow Nulls என்பதற்கு நேராக Tick செய்துள்ளோம். ஆகவே Total, Average, Result ஆகியவற்றுக்கு மட்டும் தகவல்களை உள்ளீடு செய்யவேண்டிய அவசியம் இல்லை. பிறகு ஒரு UPDATE மூலம் அவற்றைக் கணக்கிட்டுக்கொள்ளலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது இந்த அட்டவணை (Table)ல் ஒவ்வொரு Rowவாகத் தகவல்களைக் கொடுக்கப்போகிறோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதற்காக MarkStatement ல் Right Click செய்து வரும் சிறு menuவில், Open Table தேர்வுசெய்யவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj3SO4hqpNilGUBucw0oeNed4ELKMr2k1xyClOFQiuxus23WdxQ1xYb0WpIXzB7fkPsiQFz3hJaMY4Akmq2qmori_EZc7nW4Vldp2Fw2OXzMP_UFpyx71pCgXW5qaMaxcWni0m4qNYLMDPM/s1600-h/oepntable.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298206363009166866" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj3SO4hqpNilGUBucw0oeNed4ELKMr2k1xyClOFQiuxus23WdxQ1xYb0WpIXzB7fkPsiQFz3hJaMY4Akmq2qmori_EZc7nW4Vldp2Fw2OXzMP_UFpyx71pCgXW5qaMaxcWni0m4qNYLMDPM/s320/oepntable.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 172px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 305px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgWMV6tCv67zu1w4LHYtvb9jbKQ7icv3r5oJPo0vhsBbfECjsWIu8GHHhYcnZhkuV6c7EyixxQnX9MYNS3OvHWPNezFw2-pGng9Dux7ce-awC5aR1C9iMOulAFM5OWC9UuhoZhK6g-Pbkpl/s1600-h/dataentrybefore.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298206884831796546" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgWMV6tCv67zu1w4LHYtvb9jbKQ7icv3r5oJPo0vhsBbfECjsWIu8GHHhYcnZhkuV6c7EyixxQnX9MYNS3OvHWPNezFw2-pGng9Dux7ce-awC5aR1C9iMOulAFM5OWC9UuhoZhK6g-Pbkpl/s320/dataentrybefore.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 16px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே ஒவ்வொரு Rowவாக Table ல் தகவல்களை ஏற்றும்போது, Total,Average,Result ஆகியவற்றுக்கான மதிப்புகளை NULL ஆகவே விட்டுவிட்டு மற்ற Columnகளுக்கு உரிய மதிப்புகளை மட்டும் கொடுத்தால் போதும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhuknaU45hmq_3achSs3YrzL8iVvUBtKUl9TOXKsBjvQ-5tsz7cauUgL9lbuwx8yrAC2aQcO7Br3Gl5xnB5FEtiwNvvGV2PttRBocJLvgSmZb2jdwd5o2CSyJLcZNFElj3w92jsqmgE1RJe/s1600-h/dataentryafter.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298208118565743538" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhuknaU45hmq_3achSs3YrzL8iVvUBtKUl9TOXKsBjvQ-5tsz7cauUgL9lbuwx8yrAC2aQcO7Br3Gl5xnB5FEtiwNvvGV2PttRBocJLvgSmZb2jdwd5o2CSyJLcZNFElj3w92jsqmgE1RJe/s320/dataentryafter.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 137px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />நம் செயல்முறைகளுக்கு, 10 Rows மட்டும் போதும். அதற்காக இதைக் Close செய்யவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhfk4wb-hv-pMMGdXFqc4eM0XAn8gOLqYD80xEOe34ytX83DSfgSHaGr8vu0ShyphenhyphenT2H8witSoqJj_lw5Y6iczNhVtDNDkRU9MEaO3xhQFf5B4BZ4oFb3N2X46N19TUyK1A9rTmJllRVLJmvC/s1600-h/closeafterentry.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298208778587620322" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhfk4wb-hv-pMMGdXFqc4eM0XAn8gOLqYD80xEOe34ytX83DSfgSHaGr8vu0ShyphenhyphenT2H8witSoqJj_lw5Y6iczNhVtDNDkRU9MEaO3xhQFf5B4BZ4oFb3N2X46N19TUyK1A9rTmJllRVLJmvC/s320/closeafterentry.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 36px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>இப்போது, UPDATE மூலம் Total,Average,Result ஆகியவற்றை எப்படி நிரப்புவது என்பதைக் காண்போம். இதற்காக T-SQL Editorஐத் திறந்து கொள்ளவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதற்காக Databaseஐத் தேர்வு செய்தபிறகு, New Queryஎன்னும் ஒரு Toolbar ன் buttonஐத் தேர்வு செய்யவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjrJgjE1pLuVDyoGURvfhYvk4as2HCvjK65bmWl8JIlmMaZe2FxkEq-exck3c3CwWgdXxzs4xOdWzHTl-q0EL5O3vopqm7FYRoIJynZ2Ya2NVL_IiPDeyU7mh1pZ861pdq8mYR3Feres9VO/s1600-h/newquery.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298209561653445474" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjrJgjE1pLuVDyoGURvfhYvk4as2HCvjK65bmWl8JIlmMaZe2FxkEq-exck3c3CwWgdXxzs4xOdWzHTl-q0EL5O3vopqm7FYRoIJynZ2Ya2NVL_IiPDeyU7mh1pZ861pdq8mYR3Feres9VO/s320/newquery.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 85px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />வலதுபுறம் உள்ள காலியிடமே T-SQL Editor ஆகும். அங்கே கீழ்க்கண்ட வரிகளை எழுதுங்கள்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE dbo.MarkStatement</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Total = Tamil + English + Maths</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் விளைவாக Total என்கிற Columnல் மூன்று பாடங்களில் அவரவர்கள் வாங்கிய மதிப்பெண்களைக் கூட்டி வரும் விடை நிரப்பப்பட்டுவிடும். இந்த UPDATE ல் எந்த WHEREம் இல்லாததால் அனைத்து Rowsம் மாற்றப்பட்டுவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எனக்குக் கிடைத்த விடை : (10 row(s) affected)<br style="margin: 0px; padding: 0px;" />இப்போது&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MarkStatement</span>&nbsp;- இதை ஓட்டிப்பார்த்து Total Column மதிப்பை உடனே அறிந்துகொள்ளலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Average ( சராசரி ) காண்பதற்காக :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE dbo.MarkStatement</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Average = Total / 3</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />மூன்றையும் கூட்டி மூன்றால் வகுத்தால் வரும் விடை இங்கே சராசரி ஆகும் (Average).<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />கீழ்க்கண்ட வரியை இயக்கினால் எந்தெந்த மாணவர்கள் தேர்ச்சியுற்றிருக்கிறார்களோ அவர்களுக்கு மட்டும் PASS என Result Columnன் மதிப்பை மாற்றிவிடலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE dbo.MarkStatement</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">[Result] = 'PASS'</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">WHERE</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Tamil &gt;= 35 AND English &gt;= 35 AND Maths &gt;= 35</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Tamil, English, Maths ஆகிய 3 மாறுபட்ட பாடங்களிலும், அனைத்துப் பாடங்களிலும் குறைந்தபட்சம் 35 மதிப்பெண்கள் எடுத்தவர்களுக்கு PASS போட்டு விடப்படும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />AND எனப்படும் தர்க்கரீதியிலான Logical Operator ஆனது, அனைத்துக் கட்டுப்பாடுகளுக்கும் சம்மதிக்கக் கூடிய Rows ஐ மட்டும் பிரித்தெடுத்து அவைகளை மட்டும் UPDATE செய்ய அனுமதிக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />விடை : (8 row(s) affected)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />UPDATE dbo.MarkStatement<br style="margin: 0px; padding: 0px;" />SET<br style="margin: 0px; padding: 0px;" />[Result] = 'FAIL'<br style="margin: 0px; padding: 0px;" />WHERE<br style="margin: 0px; padding: 0px;" />Tamil &lt; 35 OR English &lt; 35 OR Maths &lt; 35<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" /></span>மேற்கண்ட வரியை இயக்கினால், ஏதேனும் ஒரு பாடத்தில் மட்டுமாவது 35 மதிப்பெண்களைவிடக் குறைவாகப் பெற்றவர்களுக்கு மாத்திரம் FAIL போடப்பட்டுவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />OR எனப்படும் தர்க்கரீதியிலான Logical Operator ஆனது ஏதேனும் ஒரு கட்டுப்பாட்டுக்காவது சம்மதிக்கும் Rows ஐ UPDATE செய்துவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />கிடைத்த விடை : (2 row(s) affected)<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" /></span>இப்போது&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MarkStatement</span>&nbsp;- இதை ஓட்டிப்பார்த்து Total, Average, Result Columnகளில் Update செய்யப்பட்ட மதிப்பை அறிந்துகொள்ளலாம்.<span style="font-weight: bold; margin: 0px; padding: 0px;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiHRb1p45vx4V0zl570RVqI_TvHgL1ZAcQJVkKCsRKxrRHb4ZfDGmhvo5y4tQjjYYmQCpT2a7qCrt2WDcYl3m-bnAfyKQktsTb3F0oXSRZdlOtbczj2zMEmCppOr4fooK3QUinYzizwulWW/s1600-h/markstatement.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298214223896693602" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiHRb1p45vx4V0zl570RVqI_TvHgL1ZAcQJVkKCsRKxrRHb4ZfDGmhvo5y4tQjjYYmQCpT2a7qCrt2WDcYl3m-bnAfyKQktsTb3F0oXSRZdlOtbczj2zMEmCppOr4fooK3QUinYzizwulWW/s320/markstatement.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 174px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a></span>ஹரி, மற்றும் பானு இருவர் மட்டும் தோல்வியடைந்துள்ளனர். மீதி அனைவரும் தேர்ச்சியடைந்துள்ளனர்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அதிகபட்ச மதிப்பெண்ணைக் காண :<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT MAX(total) FROM Markstatement&nbsp;</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் விடை : 267<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />MAX ( ) என்பது Maximum ஒரு உள்ளமைந்த built-in Function ஆகும். இது குறிப்பிட்ட Columnல் இருக்கும் அனைத்து மதிப்புகளிலும் மிக உயர்ந்தது எது என்பதைக் கண்டறிய உதவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஏற்கனவே முந்தைய பாடத்தில் UPPER ( ) , GETDATE ( ) போன்ற Functions ஐப் பார்த்திருக்கிறோம். அதைப் போன்றே இது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />குறைந்தபட்ச மதிப்பெண் யாது?<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="margin: 0px; padding: 0px;">SELECT MIN(Total) FROM Markstatement</span><br style="margin: 0px; padding: 0px;" /></span>இதன் விடை : 118<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" /></span>MIN( ) என்பது Minimum ஒரு உள்ளமைந்த built-in Function ஆகும். இது குறிப்பிட்ட Columnல் இருக்கும் அனைத்து மதிப்புகளிலும் மிகக் குறைவானது எது என்பதைக் கண்டறிய உதவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />முதல் மதிப்பெண்ணைப் பெற்றவர்களது தகவல்களைக் கண்டறிய :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MarkStatement&nbsp;</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">WHERE TOTAL = (SELECT MAX (Total) FROM Markstatement)</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அல்லது,<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DECLARE @M INT</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET @M= ( SELECT MAX(Total) FROM MarkStatement )</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MarkStatement WHERE Total = @M</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எனக் கொடுக்கலாம். இதன் விடை கீழே :<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi66f4ewBEvrLEMNGI5p5ihCT3ffvmR8EAzfLQFWCdfqqLeAhjkllsXfsVF7W51lngNoDm3Wd_o4Xa5Ne0hqaKhivVM26xkNxo-hZJVJxblw86KLq7d2zrRIg5P-9cKLc12RhyO9RjqTpq0/s1600-h/rank1.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5298216862211601714" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi66f4ewBEvrLEMNGI5p5ihCT3ffvmR8EAzfLQFWCdfqqLeAhjkllsXfsVF7W51lngNoDm3Wd_o4Xa5Ne0hqaKhivVM26xkNxo-hZJVJxblw86KLq7d2zrRIg5P-9cKLc12RhyO9RjqTpq0/s320/rank1.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 73px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a></span>தேர்வில் தோல்வியடைந்தவர்களின் records ஐ அழித்துவிடுவோம். அதற்காக,<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DELETE FROM MarkStatement WHERE [Result] = 'FAIL'</span></div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/433959291756216337/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-11.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/433959291756216337'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/433959291756216337'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-11.html' title='எளிய தமிழில் SQL - பாகம் 11'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhXCrsCxI-gMGczd67jxmnMOFQyFzwGudmz3jwxoUlAFAyRp93lB-QxgHxfMMVZRDZNq3pQcu9SbfR2F9FwLkeu36lEvJMMYa3onPLICBWuhQ7Hk3tJd2Ma7i5QajjRjQUcEaU-WCcX1t1s/s72-c/structureMarks.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-4156095742625803396</id><published>2013-08-08T04:53:00.003-07:00</published><updated>2013-08-08T04:53:48.004-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 10</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px;">SQL கற்பதற்கான ஒரு இலவச மென்பொருளான 2005 ஐ முந்தைய பாகங்களில் கண்டோம்.</span></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<div dir="ltr" style="margin: 0px; padding: 0px; text-align: left;" trbidi="on">
அதன் நவீன வடிவமாகிய&nbsp;<a href="http://www.microsoft.com/express/sql/download/" style="color: #2a6080; margin: 0px; padding: 0px;" target="_blank">Microsoft® SQL Server® 2008 Express with Tools</a>&nbsp;ஐ இறக்கி நிறுவிப் பயன்பெருங்கள்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="http://go.microsoft.com/?linkid=9394725" style="color: #2a6080; margin: 0px; padding: 0px;" target="_blank">SQL Server 2008 Express with Tools&nbsp;</a><br style="margin: 0px; padding: 0px;" />SQL Server database engine - create, store, update and retrieve your data<br style="margin: 0px; padding: 0px;" />SQL Server Management Studio Basic - visual database management tool for creating, editing and managing databases<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த அடிப்படைப் பயன்பாடு நமக்கு ஒத்துவரும். 2005 ஐ நிறுவியிருந்தவர்கள் அதை uninstall செய்தபிறகு இதை நிறுவவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />நேற்றையப் பதிவில் CREATE,INSERT,SELECT ஆகியவை பற்றிப் பார்த்தோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இன்றைக்கு UPDATE மற்றும் DELETE ஆகியவற்றைப் பற்றிப் பார்ப்போம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஏற்கனவே பதியப்பட்ட தகவல்களில் மாற்றங்கள் செய்வதற்கு UPDATE உதவும்.<br style="margin: 0px; padding: 0px;" />பழைய தகவல்களின் Row / Rows ஐ அழித்துவிடுவதற்கு DELETE உதவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஏற்கனவே நாம் உருவாக்கிய MyListஐ ஒரு Copy (படி) எடுத்து வைப்பதற்காக கீழ்க்கண்ட வரியை இயக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Table ஐ Copy செய்வதற்குரிய Syntax :<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />SELECT * INTO newTableName FROM oldTableName</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உதாரணம்:<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />SELECT * INTO BakupMyList FROM MyList</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் மூலம் MyList எனப்படும் நம்முடைய பழைய Tableன் Copy ஐ, புதிய BackupMyListல் எழுதி வைத்துவிடலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதை இயக்கியதும் எனக்குக் கிடைத்த விடை : (5 row(s) affected)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது UPDATE பற்றிப் பார்ப்போம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE ன் Syntax:</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE tableName</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">[fieldName] = 'newValue'</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">WHERE</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">[fieldName] ='oldValue'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உதாரணம்:<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE MyList</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] = 'Arun'</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">WHERE</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] ='valpaiyan'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />நம்முடைய MyList என்னும் Tableல் 2வது rowல் உள்ள தகவல் 2,valpaiyan,Erode - என இருந்தது. அவருடைய உண்மையான பெயர் Arun. செல்லமாக அவர் வைத்துக்கொண்ட பெயர் valpaiyan. அவருடைய செல்லப்பெயரை, உண்மைப் பெயரைக் கொண்டு மாற்றுவதற்கு - மேற்கொண்ட UPDATE பயன்படும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Person#] = 2</span>&nbsp;எனக் கொடுத்து F5 அழுத்தினால், கிடைக்கும் விடை :&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">2 Arun Erode</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />நாம் ஒரு rowல் இருக்கும் குறிப்பிட்ட Column ல் ஏற்றப்பட்ட மதிப்பை வேறு ஒரு மதிப்பைக் கொண்டு மாற்றுவதற்கு இப்போது UPDATE ஐப் பயன்படுத்தினோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">இதில் WHERE எனப்படும் கட்டுப்பாட்டை விதிக்காவிடில் என்ன ஆகும்?</span><br style="margin: 0px; padding: 0px;" />உதாரணமாக :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE MyList</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] = 'Arun'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />என்று மட்டும் கொடுத்திருந்தால் என்ன ஆகியிருக்கும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjDDKaUKrUFgY0GLmT7CHE0mwEH2If3W4YghIFj9_u9k2NF0rfNMQCKH8cnxOiY6-MTsShnS-d4U1z_6momSBKFfwE_obAqHZUyR9Un_TjKTqg3jp36npPXKdQOV4XAQF3rRRzIcBGIP0rM/s1600-h/withoutwhere.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297707058706931106" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjDDKaUKrUFgY0GLmT7CHE0mwEH2If3W4YghIFj9_u9k2NF0rfNMQCKH8cnxOiY6-MTsShnS-d4U1z_6momSBKFfwE_obAqHZUyR9Un_TjKTqg3jp36npPXKdQOV4XAQF3rRRzIcBGIP0rM/s320/withoutwhere.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 112px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 178px;" /></a><br style="margin: 0px; padding: 0px;" />இப்படி ஆகியிருக்கும். அனைவருடைய பெயரையுமே Arun என்று மாற்றியிருக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எத்தனை முறை SELECT கொடுத்தாலும், எந்தத் தகவலுமே மாறாமல் அப்படியே இருக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஆனால் UPDATE, DELETE கொடுக்கும்போது கவனமாக இருக்கவும். எதாவது தவறிழைத்துவிட்டால் - அனைத்துத் தகவலும் நொடியினில் மாறிவிடும் ஆபத்து உள்ளது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அதற்காகவே&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * INTO</span>&nbsp;கொடுத்து ஒரு backup எடுத்து வைத்துக்கொண்டேன்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த அட்டவணையில் (Table) ஏற்கனவே ஏற்றப்பட்டுள்ள 5 Rowsல் இருக்கும் [Name] Columnன் மதிப்புகள் அனைத்தையுமே பெரிய எழுத்துகளில் (CAPITAL LETTERS) மாற்றுவதற்கு என்ன செய்யவேண்டும்?<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />UPDATE MyList<br style="margin: 0px; padding: 0px;" />SET<br style="margin: 0px; padding: 0px;" />[Name] = UPPER([Name])</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே UPPER( ) என்பது ஒரு Function ஆகும். இதை உள்ளமைந்த built-in function என்போம். இது பெரிய எழுத்துகளாக மாற்றுவதற்குப் பயன்படுகிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEik6Z3X7-9V8d4B3bHXAZb9veCmhq8uJYRaohm1E4ggVXHYJ2SZDC42jMfLgXZzmUQp_Z4n7eb_Nq761fzfa04UV9duIdcVGgxVA-ZPELUcK2gXo2YImNMoT6HyY1eZuWthMf27TTqTiQGF/s1600-h/allcaps.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297708938415693442" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEik6Z3X7-9V8d4B3bHXAZb9veCmhq8uJYRaohm1E4ggVXHYJ2SZDC42jMfLgXZzmUQp_Z4n7eb_Nq761fzfa04UV9duIdcVGgxVA-ZPELUcK2gXo2YImNMoT6HyY1eZuWthMf27TTqTiQGF/s320/allcaps.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 139px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 206px;" /></a>இந்த UPPER( ) மாற்றப்பட்டவுடன் கிடைத்த விடை மேலே:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது அழிக்கும் வேலைக்கு என்ன Statement என்பதைக் காண்போம்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Syntax கீழே:<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DELETE FROM tableName WHERE Condition</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DELETE FROM&nbsp;</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">MyList&nbsp;</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">WHERE&nbsp;</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">[Person#] = 4</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் அர்த்தம் என்ன. 4வது rowவை அழித்துவிடு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-style: italic; font-weight: bold; margin: 0px; padding: 0px;">DELETE FROM MyList</span><span style="font-style: italic; margin: 0px; padding: 0px;">&nbsp;என்று WHERE ஐ நீக்கிவிட்டுக் கொடுத்தால் என்ன ஆகும்?</span><br style="margin: 0px; padding: 0px;" />ஒட்டுமொத்தமாக அனைத்து records (rows) ம் அழிந்து போகும்.<br style="margin: 0px; padding: 0px;" />ஆனால் Tableன் Structure அழியாது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">DELETE FROM MyList</span>&nbsp;இதற்குச் சமமாக வேறு ஒரு Statement ம் இருக்கிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அதன் Syntax மற்றும் உதாரணம் கீழே:<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />TRUNCATE TABLE tableName</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">TRUNCATE TABLE MyList</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">குறிப்பு :</span><br style="margin: 0px; padding: 0px;" />ஒரு Table ஆனது, அதனுடன் தொடர்புடைய இணைக்கப்பட்ட மற்றொரு Table உடன் இணைப்பில் இருந்தால் (<span style="font-style: italic; margin: 0px; padding: 0px;">Foreign Key Relationship</span>) அதை Truncate செய்ய இயலாது. Truncate ன் மூலம் ஒரு Tableல் உள்ள அனைத்து Rows ஐயும் அழித்துவிட இயலும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒரு Tableஐ வேறொரு Tableஉடன் இணைப்பதற்கு (join) Foreign key பயன்படுகிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-style: italic; margin: 0px; padding: 0px;">Structure ஐயும் சேர்த்து அழிப்பதற்கு என்ன செய்யவேண்டும்?</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Syntax :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DROP TABLE tableName</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உதாரணம்:<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DROP TABLE MyList<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;"></span></span></span></span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது ஏற்கனவே Copy செய்து வைத்திருக்கிறோமே BakupMyList என்கிற Table அதை MyList என பெயர் மாற்றுவோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்படி ஒரு Tableன் பெயரை மாற்றுவதற்கு கீழே உள்ள வரியை இயக்கலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SP_RENAME 'BakupMyList', 'MyList'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SP_RENAME என்பது ஏற்கனவே எழுதப்பட்ட ஒரு நிரல். அதனை Stored Procedure என்று அழைப்பார்கள். அதுபற்றிப் பிறகு பார்ப்போம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் Syntax:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SP_RENAME 'oldTableName', 'newTableName'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்படி ஒரு Tableன் பெயரை மாற்றும்போது, கிடைக்கும் ஒரு எச்சரிக்கைச் செய்தி:<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; font-style: italic; margin: 0px; padding: 0px;">Caution: Changing any part of an object name could break scripts and stored procedures.</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-style: italic; margin: 0px; padding: 0px;">Tableன் ஒரு குறிப்பிட்ட columnன் பெயரை மாற்ற என்ன செய்ய வேண்டும்?</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SP_RENAME 'dbo.MyList.City', 'Place', 'COLUMN'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதன் Syntax :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SP_RENAME<br style="margin: 0px; padding: 0px;" />'dbo.tableName.oldColumnName',<br style="margin: 0px; padding: 0px;" />'newColumnName', 'COLUMN'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே dbo என்பது object owner.</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/4156095742625803396/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-10.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4156095742625803396'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4156095742625803396'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-10.html' title='எளிய தமிழில் SQL - பாகம் 10'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjDDKaUKrUFgY0GLmT7CHE0mwEH2If3W4YghIFj9_u9k2NF0rfNMQCKH8cnxOiY6-MTsShnS-d4U1z_6momSBKFfwE_obAqHZUyR9Un_TjKTqg3jp36npPXKdQOV4XAQF3rRRzIcBGIP0rM/s72-c/withoutwhere.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-5442279859948749261</id><published>2013-08-08T04:53:00.000-07:00</published><updated>2013-08-08T04:53:12.945-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 9</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px;">ஒரு சிறிய Table ஒன்றை உருவாக்கிக்கொள்வோம். அதைக் கொண்டு SELECT ன் தன்மைகளை ஆராயலாம்.</span></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<div dir="ltr" style="margin: 0px; padding: 0px; text-align: left;" trbidi="on">
<br style="margin: 0px; padding: 0px;" />Table ஒன்றை உருவாக்குவதற்காக, GUI (Graphical User Interface) வழியாக என்ன செய்வதென்று ஏற்கனவே&nbsp;பாகம்-5ல் பார்த்திருக்கிறோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அதையே CUI எனப்படும் Character User Interface வாயிலாக T-SQL Editor ல் தட்டித்தட்டியே ஒரு Tableன் Structureஐ எப்படி உருவாக்குவது என்பதை இங்கே காணலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />T-SQL Editorல் எவ்வாறு நிரல் எழுதுவது? T-SQL Editorக்கு எந்த செயல்வழி மூலம் செல்வது? ஆகியவற்றைத்தெரிந்து கொள்ள -&nbsp;இங்கே&nbsp;சொடுக்கவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒரு வழியாக T-SQL Editorக்கு வந்துவிட்டோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Table ஒன்றை புதிதாக உருவாக்க உதவும் ஒரு எளிய pattern கீழே :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;">CREATE TABLE tableName</span><span style="color: #009900; margin: 0px; padding: 0px;">&nbsp;</span><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />(</span><span style="color: #009900; margin: 0px; padding: 0px;">&nbsp;</span><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />ColumnName1 datatype,</span><span style="color: #009900; margin: 0px; padding: 0px;">&nbsp;</span><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />ColumnName2 datatype,</span><br style="margin: 0px; padding: 0px;" /><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;">ColumnName3 datatype,</span><span style="color: #009900; margin: 0px; padding: 0px;">&nbsp;</span><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;">....</span><span style="color: #009900; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" /></span><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;">)</span><br style="margin: 0px; padding: 0px;" />இந்த pattern ஐ Syntax என்பார்கள். கணக்குப் பாடத்தில் ஒரு கணக்கைச் செய்வதற்கு முன் மாதிரி கணக்கைக் கொடுத்து - அதைப்போல மற்றொன்றைச் செய்யச் சொல்வார்கள். அந்த மாதிரி கணக்கு போலத்தான் இந்த Syntax.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த Syntax ல் tableName என்கிற இடத்தில் ஒரு அட்டவணையின் பெயர் (MyList), ColumnName1 என்கிற இடத்தில் Person#, LastName, FirstName, City போன்றவையும் ஒவ்வொரு DataTypeக்கு நேராக அதன் வகையையும் குறிப்பிட்டுவிட்டால் கீழ்க்கண்டமாதிரி Tableன் வடிவம் இருக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">CREATE TABLE MyList</span>&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />(</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Person# int,</span>&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />[Name] varchar(50),</span>&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />City varchar(50)</span>&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />)</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Name என்பது SQL ல் உள்ளமைந்த ஒரு தனிப்பட்ட keyword. ஆகவே அதைப் பிரித்துக் காண்பிப்பதற்காக [Name] என ஒரு அடைப்புக்குள் (Square Bracket) குறிப்பிடுகிறோம். இந்த Pattern - Syntax ஐ நிரப்பிய பிறகு F5 keyஐ விசைப்பலகையில் அழுத்தி Table ஐ உருவாக்கலாம். ஏதேனும் பிழைச்செய்தி வந்தால் அதைச் சரிசெய்தபிறகு Table உருவாகிவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Table உருவாகிவிட்டதா என்பதை எப்படி அறிவது?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒரு சிறிய SELECT வடிவம் ஒன்று.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM tableName&nbsp;</span>---&gt; ஒரு Tableல் இருக்கும் அனைத்து rowsஐயும் திரையில் காண்பிப்பதற்காக.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList</span>&nbsp;--&gt; MyList என்பது நாம் சற்று முன்னர் உருவாக்கிய Tableன் பெயரே. இதை இயக்குவதற்கு F5 அழுத்தினால் கிடைக்கும் விடை கீழே :<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi_5wU4pIpJfYpoP4jif9Grza5oJagCTPEcQVpp7IaAH2od1M1XGHRB7jHe69ZYg-Pe5P5L2X6xuZDKQ8RpeyVH4Pri_CEH6DvVqmN9VlGhLMoFsKp8IR7Bar9HqaAgdnd_Knu4YCfWw5x6/s1600-h/empty.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297398708023815074" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi_5wU4pIpJfYpoP4jif9Grza5oJagCTPEcQVpp7IaAH2od1M1XGHRB7jHe69ZYg-Pe5P5L2X6xuZDKQ8RpeyVH4Pri_CEH6DvVqmN9VlGhLMoFsKp8IR7Bar9HqaAgdnd_Knu4YCfWw5x6/s320/empty.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 67px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 169px;" /></a>இங்கே * என்பது அனைத்து rows ஐயும் குறிக்கிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />நாம் இப்போது உருவாக்கிய Persons என்கிற Tableல் எந்தவிதமான தகவலும் ஏற்றப்படவில்லை. வெறும் Structure மட்டுமே உருவாக்கப்பட்டுள்ளது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த MyList என்று சற்றுமுன்னர் உருவாக்கிய Tableல் ஒவ்வொரு rowவாக புதுப்புது தகவல்களை ஏற்றுவதற்கு என்ன செய்யவேண்டும்?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />புதிய தகவல்களை ஏற்றுவதற்கு உரிய Syntax (Pattern)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: green; margin: 0px; padding: 0px;"><b style="margin: 0px; padding: 0px;">INSERT INTO table_name<br style="margin: 0px; padding: 0px;" />(<br style="margin: 0px; padding: 0px;" />column1,<br style="margin: 0px; padding: 0px;" />column2, ...<br style="margin: 0px; padding: 0px;" />)<br style="margin: 0px; padding: 0px;" />VALUES<br style="margin: 0px; padding: 0px;" />(<br style="margin: 0px; padding: 0px;" />'value1',<br style="margin: 0px; padding: 0px;" />'value2', ...<br style="margin: 0px; padding: 0px;" />)</b></span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />நாம் நமது MyList அட்டவணைக்குத் தகுந்தாற்போல் மாற்றினால்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">INSERT INTO MyList (</span><span style="font-weight: bold; margin: 0px; padding: 0px;">Person#,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] ,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">City)</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;VALUES (1, 'Jimsha', 'Chennai')</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">INSERT INTO MyList (</span><span style="font-weight: bold; margin: 0px; padding: 0px;">Person#,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] ,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">City)</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;VALUES (2, 'Valpaiyan', 'Erode')</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">INSERT INTO MyList (</span><span style="font-weight: bold; margin: 0px; padding: 0px;">Person#,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] ,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">City)</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;VALUES (3, 'Karthik', 'Erode')</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">INSERT INTO MyList (</span><span style="font-weight: bold; margin: 0px; padding: 0px;">Person#,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] ,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">City)</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;VALUES (4, 'Vizhiyan', 'Chennai')</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">INSERT INTO MyList (</span><span style="font-weight: bold; margin: 0px; padding: 0px;">Person#,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">[Name] ,</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;</span><span style="font-weight: bold; margin: 0px; padding: 0px;">City)</span><span style="font-weight: bold; margin: 0px; padding: 0px;">&nbsp;VALUES (5, 'PKP', 'USA')</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />என 5 rowக்களுக்கான தகவல்களை 5 வரிகளில் எழுதவேண்டும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது நாம் கொடுத்த தகவல்களை திரையில் காண்பதற்கு :<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList&nbsp;</span><br style="margin: 0px; padding: 0px;" />எனத்தட்டெழுதி F5 அழுத்தவும்.<br style="margin: 0px; padding: 0px;" />விடை கீழே :<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh7R85LHJC-Qn7AJBMAgkF0hrOipOiz8RjCxgCl_CApShQak89IJmaJMJsZDh6xIG5qZjNLG1QKSU-OpQi2o8q34k9DNIcBZLO5-GZgV9NPysRwGOUBZWOOmASh_M6qdF3zSVeQkcT9dIO2/s1600-h/rowentry.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5296016453581327746" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh7R85LHJC-Qn7AJBMAgkF0hrOipOiz8RjCxgCl_CApShQak89IJmaJMJsZDh6xIG5qZjNLG1QKSU-OpQi2o8q34k9DNIcBZLO5-GZgV9NPysRwGOUBZWOOmASh_M6qdF3zSVeQkcT9dIO2/s320/rowentry.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 138px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />CREATE புதிய Tableன் Structureஐ உருவாக்க<br style="margin: 0px; padding: 0px;" />SELECT ஏற்றப்பட்ட தகவல்களைப் பார்வையிட<br style="margin: 0px; padding: 0px;" />INSERT புதிய தகவல்களை ஒன்றொன்றாகப் பதிந்திட<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SELECT ல் Wild Card Character என்று குறிப்பிட்டிருந்தேன். அது என்ன Wild Card Character?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உதாரணமாக&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList</span>&nbsp;எனக் கொடுத்தால் ஏற்றப்பட்ட 5 rowsஉம் உடனே கண்முன் வந்து நிற்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதில் குறிப்பிட்ட rowsஐ மட்டும் பார்ப்பதற்கு என்ன செய்வது? வடிகட்டுதல் நுட்பத்திற்காக SELECT உடன் WHERE எனப்படும் கட்டுப்பாட்டை உடன் இணைக்கிறோம்..<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது SELECT ன் Syntax இவ்வாறு இருக்கும்.<br style="margin: 0px; padding: 0px;" /><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM tableName WHERE Condition</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Condition என்கிற இடத்தில்&nbsp;Relational மற்றும் Logical Operators&nbsp;ஐப் பயன்படுத்தி வடிகட்டுதல் வேட்டையைத் தொடரலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />சில உதாரணங்கள்:<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * from MyList WHERE Person# = 5</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />5வது நபரின் தகவல்களை மட்டும் திரையில் காண்பதற்கு<br style="margin: 0px; padding: 0px;" />விடை :<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjxLrMHnPsIDbUKzEju3VQcn7uJQdXnSADxeXbj0Jnqm8U8NC4cSCezKz5EGYyRPqQ_JtKSuBsCiPXJ-sO6kbPGoc6LU9V1uyg2egyKFG9BYWC-1XkjBOeCpmHXOn89qD-muNBsXZC77OGN/s1600-h/5th.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297405443698506978" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjxLrMHnPsIDbUKzEju3VQcn7uJQdXnSADxeXbj0Jnqm8U8NC4cSCezKz5EGYyRPqQ_JtKSuBsCiPXJ-sO6kbPGoc6LU9V1uyg2egyKFG9BYWC-1XkjBOeCpmHXOn89qD-muNBsXZC77OGN/s320/5th.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 65px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 166px;" /></a><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE Person# &gt;=2 AND Person# &lt;= 4.</span><br style="margin: 0px; padding: 0px;" />2 முதல் 4 வரை எண்களைக் கொண்ட நபர்களின் தகவல்களைக் காண<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh8o9cebm_uhEb1DicuoonkpeSnRUNtYDf83eygqiC6hQ_sfytEVKJVbfE4C53e9Pr2CpG5MJG9RqowwottKh_1hWkzrqYFFmtD4qYeG1MOQjzY8s5pK89TlOcRZFoycBBF7AP5dKlnPkLw/s1600-h/2to4.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297405971645456930" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh8o9cebm_uhEb1DicuoonkpeSnRUNtYDf83eygqiC6hQ_sfytEVKJVbfE4C53e9Pr2CpG5MJG9RqowwottKh_1hWkzrqYFFmtD4qYeG1MOQjzY8s5pK89TlOcRZFoycBBF7AP5dKlnPkLw/s320/2to4.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 99px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 202px;" /></a><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE City = 'Erode'</span><br style="margin: 0px; padding: 0px;" />ஈரோடு நகரில் வசிக்கும் நபர்களை மட்டும் பார்க்க<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiCqyoFcMt3eEqU58lWkgKbSaT_oOkEGzn2Hb-bCKU8zTgr9uWdAVx8mUDdEqjxyAMYN5axogdDqM5mC18Cm8L6RiOBmsV5Kcyf7SR6HL24gZZXg99MZg5ZyUgMFDK_8fmayO-7kSeFiSxc/s1600-h/erode.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297406768506348322" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiCqyoFcMt3eEqU58lWkgKbSaT_oOkEGzn2Hb-bCKU8zTgr9uWdAVx8mUDdEqjxyAMYN5axogdDqM5mC18Cm8L6RiOBmsV5Kcyf7SR6HL24gZZXg99MZg5ZyUgMFDK_8fmayO-7kSeFiSxc/s320/erode.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 81px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 193px;" /></a><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * from MyList WHERE City &lt;&gt; 'Erode'</span><br style="margin: 0px; padding: 0px;" />ஈரோடு நகரை விடுத்து பிற நகரங்களில் வசிப்போர் யார் யார்?<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhusmvqaqRfOu5YBcKnudwzLO-fPo4p75_7YBNa6GoIKqYW5ZOYFzcKpsAhZueibKu0HOS347mtnaZTatuq2e_IWLzGU3ZLKXh93l5hOtOsWart27pRqL97c6R9s81feReL94_1dBG0Bymz/s1600-h/excepterode.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297407300633314418" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhusmvqaqRfOu5YBcKnudwzLO-fPo4p75_7YBNa6GoIKqYW5ZOYFzcKpsAhZueibKu0HOS347mtnaZTatuq2e_IWLzGU3ZLKXh93l5hOtOsWart27pRqL97c6R9s81feReL94_1dBG0Bymz/s320/excepterode.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 76px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 194px;" /></a>இது வரை நாம் Wild Card ஐப் பயன்படுத்தவில்லை. இப்போது பயன்படுத்திப் பார்ப்போம். Wild Card என்றால் நிரப்பிகள் எனப்படும்.<br style="margin: 0px; padding: 0px;" />Wild Card பயன்படுத்தும் Syntax வடிவம்<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: #009900; font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM<br style="margin: 0px; padding: 0px;" />tableName<br style="margin: 0px; padding: 0px;" />WHERE<br style="margin: 0px; padding: 0px;" />filedName<br style="margin: 0px; padding: 0px;" />LIKE<br style="margin: 0px; padding: 0px;" />'wild pattern'</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">LIKE 'C%'</span><br style="margin: 0px; padding: 0px;" />எனக்கொடுத்தால் C என்கிற எழுத்தில் ஆரம்பிக்கக் கூடிய எல்லாமே<br style="margin: 0px; padding: 0px;" />நகரத்தின் ஆரம்ப எழுத்து C.<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE City LIKE 'C%'</span><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhj-SE2etcNtHJAcDcAOPCju2LkioMqIxjHLol_pbQK8ex9wsDoCw2HNyf9Tag4yfccnVaXk6fAe6f_KGgBkxqhMol47kCdcGGWY80gfbBBH0IW3Dw9EiFQx-EJORzMNebM4N6uIwuFark2/s1600-h/chennaionly.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297409449687281954" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhj-SE2etcNtHJAcDcAOPCju2LkioMqIxjHLol_pbQK8ex9wsDoCw2HNyf9Tag4yfccnVaXk6fAe6f_KGgBkxqhMol47kCdcGGWY80gfbBBH0IW3Dw9EiFQx-EJORzMNebM4N6uIwuFark2/s320/chennaionly.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 79px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 192px;" /></a>LIKE '%i%'<br style="margin: 0px; padding: 0px;" />எனக் கொடுத்தால் இரண்டாவது எழுத்து i<br style="margin: 0px; padding: 0px;" />% என்பது எல்லாமே , _ என்பது ஒரு எழுத்தை மட்டும் குறிக்கிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT * FROM MyList WHERE [Name] LIKE '%i%'</span><br style="margin: 0px; padding: 0px;" />பெயரின் ஏதோ ஒரு எழுத்து i ஆக இருப்பவர்கள் யார் யார்?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiSG0QtYqInK4OyHRr-oKzn6nW8TtgbRvsFJ9OBS_jwxKeINLFl64_rj-kY0n9CLABcUdTV0hnuSUPDhhzRcopm7jyaHEZLbbf3ouAb6ckj8isLtsxPgN_1Z63hlTptKac4v0rbR9iCcuMX/s1600-h/namewithI.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297410410160516226" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiSG0QtYqInK4OyHRr-oKzn6nW8TtgbRvsFJ9OBS_jwxKeINLFl64_rj-kY0n9CLABcUdTV0hnuSUPDhhzRcopm7jyaHEZLbbf3ouAb6ckj8isLtsxPgN_1Z63hlTptKac4v0rbR9iCcuMX/s320/namewithI.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 94px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 197px;" /></a></div>
<div>
<br /></div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/5442279859948749261/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-9.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5442279859948749261'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5442279859948749261'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-9.html' title='எளிய தமிழில் SQL - பாகம் 9'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi_5wU4pIpJfYpoP4jif9Grza5oJagCTPEcQVpp7IaAH2od1M1XGHRB7jHe69ZYg-Pe5P5L2X6xuZDKQ8RpeyVH4Pri_CEH6DvVqmN9VlGhLMoFsKp8IR7Bar9HqaAgdnd_Knu4YCfWw5x6/s72-c/empty.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-735090338534934693</id><published>2013-08-08T04:52:00.003-07:00</published><updated>2013-08-08T04:52:26.991-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 8</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<a href="http://articles.techrepublic.com.com/5100-10878_11-6102265.html" style="color: #2a6080; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;" target="_blank"><span style="font-weight: bold; margin: 0px; padding: 0px;">How to install Sql Server 2005 Expression Edition?</span></a></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஏழாவது பாகத்தில் Relational operators, மற்றும் Logical Operators ஆகியவற்றைப் பார்த்தோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />Relational Operatorsல் &lt;, &gt;, &gt;=, &lt;=, =, != , &lt;&gt; போன்றவை வரும்.<br style="margin: 0px; padding: 0px;" />Logical Operatorsல் AND, OR, NOT போன்றவை வரும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒரு குறிப்பிட்ட மதிப்பானது அதிகமா, குறைவா, சமமா, சமமில்லையா என சோதித்தறிய Relational Operators பயன்படுத்தலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஒன்றுக்கு மேற்பட்ட கட்டுப்பாடுகளைத் தொடர்புபடுத்தி விடைகாண்பதற்கு Logical Operators பயன்படுத்தலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />கணிதச் சமன்பாடுகளை, கூட்டல்,கழித்தல்,வகுத்தல்,பெருக்கல் போன்ற கணக்குகளைச் செய்வதற்காக Arithmetic Operators உள்ளன.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அவை :<br style="margin: 0px; padding: 0px;" />+ கூட்டல் (Addition)<br style="margin: 0px; padding: 0px;" />- கழித்தல் (Subtraction)<br style="margin: 0px; padding: 0px;" />* பெருக்கல் (Multiplication)<br style="margin: 0px; padding: 0px;" />/ வகுத்தல் (Division)<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">உதாரணம்:</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DECLARE @a int</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DECLARE @b int</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DECLARE @c int</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET @a = 100</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET @b = 150</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET @c = @a + @b</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">PRINT @c</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />மேலே ஒரு எளிய T-SQL நிரல் (Program) ஒன்றைக் கொடுத்துள்ளேன்.<br style="margin: 0px; padding: 0px;" />@a, @b, @c ஆகியவை Variable எனப்படும். அதாவது மாறிகள். ஒவ்வொரு மாறிகளுக்கும் தனித்தனி மதிப்புகளைக் கொடுக்கிறோம். அதற்கு SET என்னும் keyword பயன்படும்.<br style="margin: 0px; padding: 0px;" />SET @c = @a + @b என்பதில் a, மற்றும் b ஆகிய இரண்டின் மதிப்பையும் + என்கிற கூட்டல் (Addition - Arithmetic Operator) அடையாளத்தைப் பயன்படுத்திக் கூட்டிக் கிடைக்கின்ற விடையை @c மூன்றாவது மாறியில் போட்டுவிடு - என அர்த்தம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />PRINT @c எனக் கொடுத்ததும் cன் மதிப்பு 250 எனத் திரையில் காட்டும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />மேற்கூரிய எளிய நிரலில் + எனப்படும் ஒரு Arithmetic Operator பயன்படுத்தியுள்ளோம்.<br style="margin: 0px; padding: 0px;" />இது போல எளிய நிரல்களை எழுதிப் பாருங்கள்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த நிரல்களை எழுதி விடை காண SQL Server Expression Edition 2005ல் நாம் என்ன செய்ய வேண்டும். அதன் வழிமுறைகளைக் காண்போம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உங்கள் Authentication எதுவாக இருக்கிறதோ அதைத் தேர்வு செய்தபிறகு, Connect ஐ அழுத்தவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgHNn7pZPTegRtXH5L5w9AGcdAAe11vYvDiSR-wPVeb719sTMBnyAhwZg4d3s4G6qKzlHSqyG25Iq8de-4wwqyiKkUCnNC9OEwNmzJUyZQXx9tlYA5ZhBad2_waa1099Q7BWnFQ-FTVhLIL/s1600-h/connect.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5296016873936840098" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgHNn7pZPTegRtXH5L5w9AGcdAAe11vYvDiSR-wPVeb719sTMBnyAhwZg4d3s4G6qKzlHSqyG25Iq8de-4wwqyiKkUCnNC9OEwNmzJUyZQXx9tlYA5ZhBad2_waa1099Q7BWnFQ-FTVhLIL/s320/connect.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 237px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>திரையில் Object Explorer என்னும் ஒரு Window தெரியும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicGDoGzJOwZIUazMCRjFWexftVig_2bC7h8Tk9JIGmEeZj0VghhaSvJZk1nlylW5OuEeNs1QqD_9G06gJESpHwRPvcRahbZRsN9Q9VhZQa9deB49Vxs6KoTOwe8mvW6wP1Ru0yvJ5kIHTs/s1600-h/objectexplorer.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5296016872552148034" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicGDoGzJOwZIUazMCRjFWexftVig_2bC7h8Tk9JIGmEeZj0VghhaSvJZk1nlylW5OuEeNs1QqD_9G06gJESpHwRPvcRahbZRsN9Q9VhZQa9deB49Vxs6KoTOwe8mvW6wP1Ru0yvJ5kIHTs/s320/objectexplorer.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 184px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a>அதில் பாகம்-5ல் நாம் ஏற்கனவே உருவாக்கிய Test எனப்படும் Database ஐத் தேர்வுசெய்யவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjLGKirhtpjTrmqYeRcCw3sJU_k9jrZIdwOlJCewTEedMmYnToW_TIYSl-l43VIXQ79EwTP8Ov10P2LB8cg-f7Y9_jEtkrf8Ysj_Uy1XRJPnAQW1P37SlX4uWBcaauXw8j5zNaxA7Wrp8Z5/s1600-h/databaseexpand.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5296016726096603906" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjLGKirhtpjTrmqYeRcCw3sJU_k9jrZIdwOlJCewTEedMmYnToW_TIYSl-l43VIXQ79EwTP8Ov10P2LB8cg-f7Y9_jEtkrf8Ysj_Uy1XRJPnAQW1P37SlX4uWBcaauXw8j5zNaxA7Wrp8Z5/s320/databaseexpand.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 293px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 319px;" /></a><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEginrdMGUQkJSShjISitvF-TUZDsl3UopWxEwe05WO717v2xGY5Kyq1yYZgvM0mPeGYkX6P9O79Px3FkWr1NFI23FMisEu8AqlkLKEegdjvtflTSkaeOuaNlsY94SHwXHkseA7ENg0eF38Z/s1600-h/testsel.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297146005701377314" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEginrdMGUQkJSShjISitvF-TUZDsl3UopWxEwe05WO717v2xGY5Kyq1yYZgvM0mPeGYkX6P9O79Px3FkWr1NFI23FMisEu8AqlkLKEegdjvtflTSkaeOuaNlsY94SHwXHkseA7ENg0eF38Z/s320/testsel.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 157px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 250px;" /></a><span style="font-weight: bold; margin: 0px; padding: 0px;">File ==&gt; New ==&gt; Query with New Connection&nbsp;</span>இதைக் கிளிக்கவும்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgn2mu6j5sb1Mi4_pesqK8ZAcICGqsjHuroPNMGPd8bQwE5DlUDJlWtz2wwRMPYS3YCLvs-xA3R2TyxGtyu9HzApUs5ynniSqY62-qSYeOzdyJcUiBvp3NIlkBjvq6CYM4-Edn5of9Cu54_/s1600-h/ctrln.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297146008700669650" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgn2mu6j5sb1Mi4_pesqK8ZAcICGqsjHuroPNMGPd8bQwE5DlUDJlWtz2wwRMPYS3YCLvs-xA3R2TyxGtyu9HzApUs5ynniSqY62-qSYeOzdyJcUiBvp3NIlkBjvq6CYM4-Edn5of9Cu54_/s320/ctrln.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 104px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />உடனே ஒரு வெள்ளைத் திரை கண் முன்னர் நிற்கும். இதுதான் T-SQLக்கான Editor. இதில் நாம் நிரல்களை எழுதிப் பழகலாம்.<br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgerSwVziyACVfDjzsD7ksXcQCJXKKpBiJR0-jKptHpwrvwccmymcV9yfFBdUQ5h_na2e0dCP7oLtoKZBk8CSRK2wG39MGIoVlUub7pqXG5CBYNoCBiyHl0WveiFhS2aQalib8yPk3YWPf9/s1600-h/proeditor.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297146006316293170" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgerSwVziyACVfDjzsD7ksXcQCJXKKpBiJR0-jKptHpwrvwccmymcV9yfFBdUQ5h_na2e0dCP7oLtoKZBk8CSRK2wG39MGIoVlUub7pqXG5CBYNoCBiyHl0WveiFhS2aQalib8yPk3YWPf9/s320/proeditor.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 112px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 320px;" /></a><br style="margin: 0px; padding: 0px;" />நிரல் எனப்படும் Programஐ எழுதிய பிறகு அதை இயக்கிப் பார்க்க F5 விசையை அழுத்தவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த Programன் விடை கீழே உள்ள சட்டத்தில் 250 எனக் காட்சியளிக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi72Vrwfk-42O6Rjr-jyNzx7LaTM8qRhiboNCUXBud9PGfL-ZDVSItro4phQrr7YAFjK8_bvVGcxtBlDANzh-iNdGnnvmqknAg7_zMtx6LqWV7nfVWzdGBt6Vnpdv_UM5I51Dfpq0mVOrFV/s1600-h/answer.png" style="color: #2a6080; margin: 0px; padding: 0px;"><img alt="" border="0" id="BLOGGER_PHOTO_ID_5297146166811312162" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi72Vrwfk-42O6Rjr-jyNzx7LaTM8qRhiboNCUXBud9PGfL-ZDVSItro4phQrr7YAFjK8_bvVGcxtBlDANzh-iNdGnnvmqknAg7_zMtx6LqWV7nfVWzdGBt6Vnpdv_UM5I51Dfpq0mVOrFV/s320/answer.png" style="border: 1px solid rgb(238, 238, 238); cursor: pointer; display: block; height: 119px; margin: 0px auto 10px; padding: 5px; text-align: center; width: 257px;" /></a><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த programல் சில இடங்களில் நான் வேண்டுமென்றே தவறு செய்கிறேன். பிழைச்செய்தி எப்படி வருகிறது என்பதைக் காண்பதற்காகத்தான்.<br style="margin: 0px; padding: 0px;" />DECLARE @a int<br style="margin: 0px; padding: 0px;" />DECLARE @b int<br style="margin: 0px; padding: 0px;" /><span style="color: #990000; font-weight: bold; margin: 0px; padding: 0px;">DECLAR @c int</span><span style="color: #990000; margin: 0px; padding: 0px;">&nbsp;---&gt; தவறு (1) ஒரு E எழுத்தை விட்டுவிடுகிறேன்.</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />SET @a = 100<br style="margin: 0px; padding: 0px;" />SET @b = 150<br style="margin: 0px; padding: 0px;" />SET @c = @a + @b<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: #990000; font-weight: bold; margin: 0px; padding: 0px;">PRINTT @c</span><span style="color: #990000; margin: 0px; padding: 0px;">&nbsp;----&gt; தவறு (2) ஒரு T எழுத்தை அதிகமாகக் கொடுக்கிறேன்.</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இப்போது F5 key ஐ அழுத்தி விடையை எதிர்பார்த்தால் என்ன கிடைக்கிறது?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Msg 102, Level 15, State 1, Line 3</span><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Incorrect syntax near 'DECLAR'.</span><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Msg 137, Level 15, State 1, Line 6</span><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Must declare the scalar variable "@b".</span><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Msg 137, Level 15, State 2, Line 7</span><br style="margin: 0px; padding: 0px;" /><span style="color: #cc0000; margin: 0px; padding: 0px;">Must declare the scalar variable "@b".</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எந்தெந்த வரிகளில் பிழைகள் என்பதைக் கீழே உள்ள சட்டத்தில் காட்டிவிடும். பிழைகளைச் சரிசெய்தபிறகுதான் விடை கிடைக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இன்றையத் தேதி என்னவென்பதை T-SQL வாயிலாக எப்படிக் கண்டுபிடிப்பது?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DECLARE @today datetime</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SET @today = getdate()</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">PRINT @today</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இங்கே @today என்பது ஒரு மாறி (Variable). அதனுடைய Data Type ஆனது datetime வகையைச் சேர்ந்தது.&nbsp;<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />getdate( ) என்பதை Function என்போம். இந்த Function ஆனது இன்றைய தேதிநேரத்தைக் கண்டறிய உதவும். அதை @today ல் பதிந்துவிடும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />PRINT @today எனக் கொடுத்ததும் கிடைத்த விடை :<br style="margin: 0px; padding: 0px;" />Jan 30 2009 11:32PM<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதை மிகச் சுருக்கமாக :&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">PRINT getdate( )&nbsp;</span>என்றும் கொடுக்கலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="color: #009900; font-size: 11px; margin: 0px; padding: 0px;"><span style="font-weight: bold; margin: 0px; padding: 0px;">குறிப்பு : எழுதிய program ஐ இயக்கி / ஓட்டி / run / execute செய்து பார்ப்பதற்கு F5 விசையை keyboardல் அழுத்த வேண்டும்.</span></span>&nbsp;</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/735090338534934693/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-8.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/735090338534934693'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/735090338534934693'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-8.html' title='எளிய தமிழில் SQL - பாகம் 8'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgHNn7pZPTegRtXH5L5w9AGcdAAe11vYvDiSR-wPVeb719sTMBnyAhwZg4d3s4G6qKzlHSqyG25Iq8de-4wwqyiKkUCnNC9OEwNmzJUyZQXx9tlYA5ZhBad2_waa1099Q7BWnFQ-FTVhLIL/s72-c/connect.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-7636111778297917262</id><published>2013-08-08T04:51:00.001-07:00</published><updated>2013-08-08T04:51:26.491-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 7</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: white; font-family: Times, serif; font-size: 31px; font-weight: normal; line-height: 1.4em; margin: 0px; padding: 0px;">
<span style="font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; text-align: justify;">ஏற்கனவே பதிந்துள்ள தகவல்களைத் தேடி எடுக்கும்போது மேலே குறிப்பிட்டுள்ள அடையாளங்களைப் பயன்படுத்தி வடிகட்டலாம். மில்லியன் கணக்கில் பதிந்திருக்கும் recordsல் இருந்து குறிப்பிட்ட சில rows (records) ஐ மட்டும் நமது தேவைக்காகத் தேடி எடுக்கும் செயலுக்குத் துணைபுரிபவை Queries ஆகும். DQL என்றால் Data Query Language.</span></h3>
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<br style="margin: 0px; padding: 0px;" />இதற்கு SELECT எனப்படும் கட்டளையைப் பயன்படுத்துகிறோம். SELECT என்றால் தேர்வு செய் என அர்த்தம். ஆயிரக்கணக்கான, லட்சக்கணக்கான தகவல்களில் இருந்து நமது தேவைக்கேற்ற தகவலை மட்டும் தேடியெடுத்துத் தருவதற்கு SELECT ஐப் பயன்படுத்தலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">ஒரு மிக மிக எளிய உதாரணம் ஒன்று.</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />முன்பெல்லாம் 10ம் வகுப்பு, 12ம் வகுப்பு தேர்வு முடிவுகள் அறிவிக்கப்பட்ட நாளின்போது மாலைப்பதிப்பு நாளிதழ்களான மாலைமுரசு, மாலைமலர் போன்றவற்றில் தேர்வில் தேரியோரின் எண்கள் வெளிவரும். பின்பு காலைப்பதிப்பிலும் வேறு வேறு நாளிதழ்களில் வெளிவரும். இன்றும் கூட இது நடைமுறையில் இருக்கும் ஒன்றுதான்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />6,75,643 மாணவர்கள் தேர்வெழுதினார்கள் எனில் அதில் 80% தேர்வாகி இருந்தால் 540514 பேர்களின் எண்கள் கல்விமாவட்ட வாரியாக நாளிதழில் வெளியாகி இருக்கும். இதில் ஒவ்வொருவரின் எண்ணும் வந்திருக்கிறதா? இல்லையா? என பட்டிமன்றமே நடக்கும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />ஆனால் தற்போது தேர்வு அறிக்கைகளும், தேர்வு முடிவுகளும் இணையத்தில் வெளியிடுகிறார்கள். நாம் நமது பதிவெண்ணை மட்டும் கொடுத்தால் உடனே முடிவுகள் மட்டுமல்லாமல் ஒவ்வொரு பாடத்திலும் எவ்வளவு மதிப்பெண்கள் எடுத்துள்ளோம் என்பது முதற்கொண்டு நொடிகளில் திரையில் காட்சியளிக்கிறது.இது எவ்வாறு சாத்தியம்?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />6,75,643 பேர்களின் தகவல்கள் அனைத்தையும் ஒவ்வொரு record (row) ஆக கணினியில் உள்ள Databaseல் ஏற்றிவிடுவார்கள். இதற்கு ஒரு குழு இயங்கும். அவர்கள் ஒவ்வொருவரின் பதிவெண், பள்ளியின் பெயர், பாடங்கள், ஒவ்வொரு பாடத்திலும் எத்தனை மதிப்பெண்கள் பெறப்பட்டன போன்றவற்றை Databaseல் ஏற்றிவிடுவார்கள். இந்த குழு மின்னல் வேகத்தில் தகவல்களை ஏற்றிவிடும் வல்லமை கொண்டது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எல்லோருடைய தகவல்களும் ஒட்டுமொத்தமாக Databaseல் ஏற்றப்பட்டவுடன் முடிவு அறிக்கைத் தேதியை வெளியிடுவார்கள்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />தேர்வு முடிவு நாள் அன்று நாம் என்ன செய்கிறோம். நமது பதிவெண்ணையோ / நண்பர்கள் / உறவினர்களின் பதிவெண்ணையோ மட்டும் கணினியில் உள்ளிடுகிறோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எனது நண்பரின் பதிவெண் 059169 எனக் கொண்டால், இந்தக் குறிப்பிட்ட 059169 என்கின்ற எண்ணை 6,75,643 பேர்களின் தகவல்கள் அடங்கிய Databaseல் இருந்து நொடிகளில் தேடியெடுத்துவிடும் வல்லமை SELECT கட்டளைக்கு உண்டு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />எனது பதிவெண்ணுக்காக ஏற்கனவே என்ன தகவல்கள் ஏற்றப்பட்டிருக்கிறதோ அனைத்தையும் திரையில் காணலாம். இந்தத் தேடியெடுத்துத் தருவதுதான் QUERY எனப்படுகிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இதற்காக SELECT கட்டளையுடன் உறுதுணையாக உதவுவதற்குப் பயன்படுபவையே Operators ஆகும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">Operatorsகளையும் அவற்றிற்கான பயன் மற்றும் குறுவிளக்கம் : கீழே</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />059169 எண்ணுக்கு உரிய தகவல்களை எனக்காகக் காண்பி = Equal<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />தேரியோர்களை மட்டும் காண்பி = Equal<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />தேராதவர்களைக் காண்பிக்காதே &lt;&gt; Not equal<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />80%க்கு மேல் மதிப்பெண்கள் வாங்கியோர் யார் யார்? &gt; Greater than<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />50%க்குக் கீழே வாங்கியோர் யார் யார்? &lt;= Less than or equal<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />34 மதிப்பெண்கள் அல்லது அதைவிடக் கீழே எடுத்தவர்கள் யார் யார்?&lt;= Less than or equal கணக்குப் பாடத்தில் 80லிருந்து 100க்குள் எத்தனை பேர் மதிப்பெண்கள் எடுத்தனர் BETWEEN Between an inclusive range ஒரு குறிப்பிட்ட எழுத்தில் ஆரம்பிக்கும் பெயர்களையுடையவர்கள் யார் யார்? LIKE Search for a pattern குறிப்பிட்ட SET { } க்குள் அகப்படும் தகவல்களை மட்டும் எடுத்துக்கொண்டு வா IN If you know the exact value you want to return for at least one of the columns இது போக AND, OR, NOT எனப்படும் மூன்று முக்கிய Operators உள்ளன. இவற்றின் பயன் என்னவென்றால் தேடியெடுக்கும் முடிவுகளைக் கட்டுப்படுத்துவதே. இத்தனை லட்சம் தகவல்களில் நமக்குத் தேவைப்படும் தகவல்களை மட்டும் வடிகட்டி எடுப்பதற்கு இந்த Operators தான் காரணம். AND -- தேடும்போது எத்தனை கட்டுப்பாடுகள் விதிக்கிறோமோ, அத்தனை கட்டுப்பாடுகளுக்கும் சம்மதிக்கக் கூடிய தகவல்களை மாத்திரம் எடுத்து வருவதற்கு. உதாரணம்: 5 பாடங்களில் அனைத்துப் பாடங்களிலும் தேரியிருந்தால் மட்டுமே மாணவர் அடுத்த வகுப்புக்குச் செல்லும் தகுதியடைகிறார். அதாவது அனைத்துக் கட்டுப்பாடுகளுக்கும் சம்மதித்திருக்கிறார். கட்டுப்பாடுகள் என்பதை Condition என்பதற்காகக் கொடுத்திருக்கிறேன். 5 Conditions இருக்கின்றன. அனைத்து Condition களும் ஏற்றுக்கொள்ளப்பட்டிருக்க வேண்டும். அதுவே AND Operatorன் வெற்றியை உறுதிப்படுத்தும். OR -- தேடும்போது இந்தக் கட்டுப்பாடோ அல்லது வேறொன்றோ எதாவது ஒன்றுக்குச் சம்மதிக்கக் கூடிய தகவல்களைக் கொணர்வதற்கு. 5 பாடங்களில் ஏதேனும் ஒன்றில் தேர்ச்சியடையாவிட்டாலும் ஒட்டுமொத்தமாக மாணவரானவர் தேர்வில் தவறிவிட்டார். இதற்கு OR. இந்தப் பாடம் அல்லது அந்தப் பாடம், அல்லது வேறொன்று எதாவது ஒன்றில் தேர்வடையாவிட்டாலும் ஒட்டுமொத்தமாக FAIL எனக் குறிப்பிட OR பயன்படுத்தலாம். 5 Conditionsல் ஏதேனும் ஒரு Condition மட்டும் Satisfy ஆனாலே ORன் வெற்றி தீர்மாணிக்கப்பட்டு விடுகிறது. NOT - எந்தக் கட்டுப்பாடு விதிக்கிறோமோ அதற்கு முரண்பாடான தகவல்களைப் பெறுவதற்கு. உதாரணமாக தேர்வில் தேறாதவர்களை மட்டும் காண்பி. இதற்கு NOT உதவும். AND, OR, NOT இவற்றை தர்க்க ரீதியிலான செயல்பாடுகள் என்போம். அதாவது Logical Operators. நீ தவறைச் செய்தால் தண்டிக்கப்படுவாய் - நேர்மறை. நீ தவறைச் செய்யாவிட்டால் தண்டிக்கப்படமாட்டாய் -- இந்த மாதிரி இடங்களில் NOT பயன்படுத்தலாம்.<div style="margin: 0px; padding: 0px; text-align: center;">
<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">= Equal</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">&lt;&gt; Not equal</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">&gt; Greater than</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">&gt;= Greater than or equal</span><br style="margin: 0px; padding: 0px;" /><span style="margin: 0px; padding: 0px;">&lt;= Less than or equal</span><br style="margin: 0px; padding: 0px;" /><span style="margin: 0px; padding: 0px;">BETWEEN Between an inclusive range</span><br style="margin: 0px; padding: 0px;" /><span style="margin: 0px; padding: 0px;">LIKE Search for a pattern</span><br style="margin: 0px; padding: 0px;" /><span style="margin: 0px; padding: 0px;">IN If you know the exact value you want to return for at least one of the columns</span></span></div>
<div>
<span style="font-weight: bold; margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;"><br /></span></span></div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/7636111778297917262/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-7.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7636111778297917262'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7636111778297917262'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-7.html' title='எளிய தமிழில் SQL - பாகம் 7'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-6699699390592223057</id><published>2013-08-08T04:50:00.002-07:00</published><updated>2013-08-08T04:50:38.568-07:00</updated><title type='text'> எளிய தமிழில் SQL - பாகம் 6</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<br /><br />
<div class="post-body entry-content" style="background-color: white; font-family: Georgia, Times, serif; font-size: 13px; line-height: 20.984375px; margin: 0px; padding: 0px; text-align: justify;">
<div style="margin: 0px; padding: 0px; text-align: center;">
<span style="font-weight: bold; margin: 0px; padding: 0px;">DQL: SELECT</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DML: DELETE, INSERT, UPDATE</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DDL: CREATE, DROP, TRUNCATE, ALTER</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">TCL: COMMIT, ROLLBACK, SAVEPOINT</span><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DCL: GRANT, REVOKE</span></div>
<br style="margin: 0px; padding: 0px;" />மேலே சில கட்டளைகளை (Commands)கொடுத்துள்ளேன். இந்தக் கட்டளைகள் மூலம் Databaseஐ நாம் நமது கட்டுப்பாட்டுக்குள் கொண்டு வரலாம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />DQL என்பது&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">Data Query Language</span>. ஒரு Databaseன் Tableல் ஏற்கனவே நாம் பதிந்துவைத்துள்ள தகவல்களை தேடி எடுப்பதற்கு. உதாரணமாக 1000 rows இருப்பதாகக் கொள்வோம். அதில் குறிப்பிட்ட சில rows மட்டும் நமக்குத் தேவையெனில் அவற்றை மட்டும் தேடி எடுக்க DQL . இதற்காக SELECT என்கிற கட்டளை பயன்படும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />DML என்பது&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">Data Manipulation Language</span>. ஏற்கனவே பதிந்துவைத்திருக்கும் தகவல்களில் மாற்றங்களை ஏற்படுத்த, அழிக்க, உருவாக்க. (தகவல்களைத் தான் மாற்றுகிறதே ஒழிய ஒரு Tableன் Structureல் எந்த மாற்றமும் நிகழாது).<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />DDL என்பது&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">Data Definition Language</span>. புதிய Database (அ) Table போன்றவற்றை உருவாக்க. அதாவது Tableன் Structure ஐ உருவாக்க, ஒட்டுமொத்த Table ஐயுமே அழிக்க, மாற்றங்கள் செய்ய. ஒரு குறிப்பிட்ட Column ன் Data Type ஐ மாற்ற.புதிய Column ஐ உருவாக்க, தேவையற்ற Column இருப்பின் அதை நீக்க.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />TCL என்றால்&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">Transaction Control Language</span>. ஒரு நிரலை இயக்கும்போது ஏதேனும் பிழைகள் ஏற்பட்டால், பிழை ஏற்படுவதற்கு முன்னர் வரை ஏதேனும் மாற்றங்கள் நிகழ்ந்திருந்தால் அவையனைத்தையும் நிராகரித்து முந்தைய நிலைக்குக் கொண்டு செல்வதற்கு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />TCL பற்றி சிறிது விளக்கமாகப் பார்ப்போம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உதாரணமாக ஒன்றுக்கு மேற்பட்ட Database அல்லது Tableகளில் நாம் ஒரு குறிப்பிட்ட Program ஐ இயக்குவதாகக் கொள்வோம். ஒரு Tableல் உள்ள ஒரு மதிப்பைக் கழித்து (முதலாவது செயல்), அடுத்த Tableல் உள்ள ஒரு குறிப்பிட்ட மதிப்புடன் கூட்டச் செய்ய(இரண்டாவது செயல்) முயற்சிக்கிறோம்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />முதல் செயல் நல்லபடியாக நிறைவுற்றுவிடுகிறது. ஆனால் இரண்டாவது செயல் நிறைவேறுவதற்கு முன்னர் ஏதேனும் தொழில்நுட்பக் கோளாறு நிகழ்ந்தால் என்ன ஆகும்?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />முதலாவது Tableல் அந்த மதிப்பு கழிக்கப்பட்டு இருக்கும். ஆனால் கோளாறு காரணமாக இரண்டாவது Tableல் அந்த மதிப்பு கூட்டப்பட்டு இருக்காது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />அப்படியெனில் இதை ஒரு சரியான நிகழ்வாக ஏற்றுக்கொள்ளக் கூடாது. முதலில் கழிக்கப்பட்ட மதிப்பை reverse செய்து , தலைகீழாக மீண்டும் பழைய நிலைக்குக் கொண்டுவந்துவிட வேண்டும். அப்போதுதான் முறையான நிகழ்வு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">நல்ல உதாரணம் ஒன்று:</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உங்களது வங்கியின் ATM அட்டையை, ATM இயந்திரத்தில் செருகி பணம் எடுக்க முயற்சிக்கிறீர்கள். எத்தனை ரூபாய் பணம் என்பதையும் தட்டிவிட்டீர்கள். இயந்திரமானது பணத்தை எண்ணிக்கொண்டிருக்கும் சத்தம் கேட்கிறது. திடீரென்று கோளாறு. Battery down - Power Cut. ஏதோ ஒரு கோளாறு. என்ன ஆகும்?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />பணம் உங்கள் கைக்கு வராது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />உங்கள் வங்கிக்கணக்கிலிருந்து பணம் எடுக்கப்பட்டுக் கழிக்கப்பட்டு இருக்கும். ஆனால் உங்கள் கைக்குப் பணம் வந்திருக்காது. இப்படியே விட்டுவிட்டால் முறையாகுமா?<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />இந்த மாதிரி இக்கட்டான சமயத்தில் உதவுவதுதான்&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">Transaction Control.</span>&nbsp;TCL ன் பணி என்னவென்றால் ஏதேனும் பிழை ஏற்பட்டிருக்கும்போது அதைத் தலைகீழாக ஆக்கி, reverse செய்து (Undo) ஒட்டுமொத்த செயல்களையும் பழைய நிலைக்கு ஆக்குவதே.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />TCL இருப்பதால் உங்கள் வங்கிக்கணக்கிலிருந்து கழிக்கப்பட்ட பணமானது, இயந்திரக்கோளாறு ஏற்பட்ட உடனேயே, தலைகீழ் இயக்கத்தால் திரும்ப உங்கள் accountல் சேர்க்கப்பட்டுவிடும்.<br style="margin: 0px; padding: 0px;" /><span style="font-size: 11px; margin: 0px; padding: 0px;"><br style="margin: 0px; padding: 0px;" />(இது எனக்கு இரண்டுமுறை நடந்து இருக்கிறது. கடந்த 3 ஆண்டுகளில் இரண்டுமுறை இந்த TCL இயக்கத்தால் பணம் பரிபோகாமல் தப்பித்தது.)</span><br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />1) எந்தப் பிழையும் நிகழாமல் இருக்கும்போது ஒட்டுமொத்த நிரலும் நல்லபிள்ளையாக இயங்கி பரிவர்த்தனையை ஒழுங்காக நிறைவு செய்யும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />2) ஏதேனும் பிழை ஏற்பட்டால் உடனே நிரலானது தனது இயக்கத்தை நிறுத்திவிட்டு, அதுவரை செய்யப்பட்ட இயக்கத்தை reverse செய்து தகவல் இழப்பைத் தடுத்துவிடுகிறது.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />முந்தைய பாடத்தில் Authorization பற்றிப் பார்த்தோம். ஒரு குறிப்பிட்ட பயனாளருக்கு ஒரு Databaseஐப் பார்வையிட மட்டும் அனுமதிக்க DCL உதவும்.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" />DCL என்றால்&nbsp;<span style="font-weight: bold; margin: 0px; padding: 0px;">Data Control Language.</span>&nbsp;ஒரு குறிப்பிட்ட பயனர் உருவாக்கிய Database,Table களின் உரிமங்களை அடுத்த பயனாளருக்கு விட்டுத்தருவதற்கு. அல்லது அடுத்தவருக்கு விட்டுத்தந்த சலுகைகளை நிராகரிப்பதற்கு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">GRANT&nbsp;</span>என்றால் சலுகைகளை வழங்குவது. உரிமங்களை வழங்குவதற்கு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">REVOKE&nbsp;</span>என்றால் கொடுத்த சலுகைகளை / உரிமைகளைத் திரும்பப் பெருவதற்கு.<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DROP&nbsp;</span>என்பது ஒட்டுமொத்த Database (அ) Table ஐ அழிப்பதற்கு (தகவலும், Structureம் அழிந்துவிடும்).<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">TRUNCATE&nbsp;</span>என்பது தகவல்களை மட்டும் அழிப்பதற்கு (Structure அழியாது).<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">SELECT&nbsp;</span>பதியப்பட்ட தகவல்களைத் தேடித் தருவதற்கு<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">INSERT&nbsp;</span>புதிய rowவை உருவாக்க<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">UPDATE&nbsp;</span>பழைய rowன் தகவலை மாற்றுவதற்கு<br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">DELETE&nbsp;</span>பதிந்திருக்கும் row / rows ஐ அழிப்பதற்கு<br style="margin: 0px; padding: 0px;" /><br style="margin: 0px; padding: 0px;" /><span style="font-weight: bold; margin: 0px; padding: 0px;">CREATE</span>&nbsp;புதிய Database / Table ஐ உருவாக்க&nbsp;</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/6699699390592223057/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-6.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/6699699390592223057'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/6699699390592223057'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-6.html' title=' எளிய தமிழில் SQL - பாகம் 6'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-4748888094657262464</id><published>2013-08-08T04:30:00.003-07:00</published><updated>2013-08-08T04:30:20.713-07:00</updated><title type='text'> எளிய தமிழில் SQL - பாகம் 5</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<span style="color: #141a87; font-family: SooriyanDotCom, Sooriyan, Arial, Tahoma; line-height: 1.4em;">SQL</span><br />
<div class="content clearfix" style="clear: left; color: #141a87; font-family: SooriyanDotCom, Sooriyan, Arial, Tahoma; line-height: 1.4em; margin: 0px; min-height: 3em; overflow: hidden; padding: 0px;">
<div style="margin: 0px; padding: 0px;">
Server 2005 Express Edition ஆனது Microsoft நிறுவனத்தால்வழங்கப்படும் ஒரு<br />
இலவச மென்பொருள். இதை நீங்கள் Microsoft தளத்திலிருந்து&nbsp;<a href="http://www.microsoft.com/downloads/details.aspx?FamilyID=220549b5-0b07-4448-8848-dcc397514b41&amp;DisplayLang=en" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank">இந்த Link</a><br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Database ல் நாம் என்ன செய்யப்போகிறோம்?</strong><br />
<br style="margin: 0px; padding: 0px;" />
CRUD என்கிற Create, Read, Update, Delete இந்தச் செயல்களைத்தான் செய்யப்போகிறோம்.<br />
<br style="margin: 0px; padding: 0px;" />
MySQL ஐ Sun Micro System வாங்கிவிட்டாலும் அதன் MySQL Community Server ஐ இலவசமாகவே வழங்குகிறது. அதைத் தரவிறக்கம் செய்வதற்கு&nbsp;<a href="http://dev.mysql.com/downloads/mysql/5.1.html#downloads" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank">இங்கே</a><br />
<br style="margin: 0px; padding: 0px;" />
ஆனால்MySQL<br />
Enterprise Edition ஆனது இலவசமன்று. நான் அலுவலகத்திலும்,வீட்டிலும் SQL<br />
Server 2005ன் Express Edition தான் பயன்படுத்துகிறேன்.<br />
<br style="margin: 0px; padding: 0px;" />
இந்தமென்பொருளை<br />
நிறுவும்போது Administratorக்கான User name, passwordமுதலியவற்றைக்<br />
கேட்கும். அவற்றைக் கொடுக்கவும். மேலும் அவற்றை நினைவில்கொள்ளவும்.<br />
<br style="margin: 0px; padding: 0px;" />
முறைப்படி நிறுவிய பிறகு Sql Server Express ஐ இயக்கவும். இதற்கு ஒரு குறுக்குவழியாக&nbsp;<strong style="margin: 0px; padding: 0px;">Start ==&gt; Run ==&gt; SQLWB&nbsp;</strong>எனக் கொடுத்தால் உடனே பயன்பாட்டின் முதல் திரை கண்முன்னே நிற்கும்.<br />
<br style="margin: 0px; padding: 0px;" />
பாதுகாப்புகாரணங்களுக்காக<br />
உங்களிடம் பயனர் கணக்கையும், கடவுச்சொல்லையும் (User name&amp; password)<br />
எதிர்பார்க்கும். Install செய்யும்போது என்னகொடுத்தீர்களோ அதைக் கொடுத்து<br />
உள்ளே செல்லலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
நிறுவும்போதேஎந்தவிதமான நுழைவாயில் என்பதைக்<br />
கூறிவிடுங்கள். அதாவது Authenticationஆனது Windows Authentication அல்லது<br />
SQL Server Authentication இரண்டில்எதோ ஒன்றா? அல்லது இரண்டுமா? என்பதைக்<br />
கூறிவிடவும்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Authentication என்றால் என்ன?</strong><br />
சரியானபயனர்<br />
பெயரும், Passwordம் கொடுத்தால் மட்டுமே உள்நுழைய அனுமதிக்கும்செயல். என்<br />
வீடு பூட்டியிருக்கிறது. வீட்டிற்கு இரண்டு சாவிகள். ஒன்றுஎன்னிடமும்,<br />
மற்றொன்று மகனிடம் உள்ளது. சரியான சாவியைப் போட்டு நானோஅல்லது மகனோ<br />
திறக்கலாம். தவறான சாவியைப் பிரயோகம் செய்தால் வீட்டைத்திறக்க இயலாது.<br />
இதுவே Authentication எனப்படும். முறையான User Nameமற்றும் Password<br />
கொடுக்கும் செயல்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Authorization என்பது என்ன?</strong><br />
ஒருஅலுவலகத்தில்<br />
30 பேர் வேலை செய்கிறார்கள் என வைத்துக்கொள்வோம். அதில்அனுபவ முதிர்ச்சி<br />
கொண்டவர், தற்போதுதான் கல்வியை முடித்து முதன்முதலாகவேலைக்கு வருபவர்,<br />
அனைவருக்கும் மூத்த தலைவர் எனப் பலவித பணியாளர்கள்இருப்பார்கள்.<br />
ஒவ்வொருவருக்கும் ஒவ்வொரு பணி. இதில் யாருக்கு அதிக சிறப்புஉரிமைகள்<br />
கொடுக்கப்படுகின்றன, யாருக்குப் பல உரிமைகள் மறுக்கப்படுகின்றன -என்பதே<br />
Authorization ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
Chess விளையாட்டில் சிப்பாய்,மந்திரி, யானை,<br />
குதிரை, அரசன், அரசி என அனைவருக்கும் ஒவ்வொரு உரிமைகள்இருக்கும்.<br />
ஒருவருக்கு இருக்கும் சிறப்பு உரிமைகள் அடுத்தவருக்குஇருக்காது. அதுதான்<br />
Authorization.<br />
<br style="margin: 0px; padding: 0px;" />
Authentication செயலானது முடிந்தபிறகு Authentication சரிபார்க்கும் செயல் நடைபெறும்.<br />
<br style="margin: 0px; padding: 0px;" />
Administrator என்பவருக்கு மிக அதிக உரிமை. இது போல ஒவ்வொரு பயனருக்கும் ஒவ்வொருவிதமான உரிமைகள். இதை Role என்பார்கள்.<br />
<br style="margin: 0px; padding: 0px;" />
நமது கணினியில் நாமே நிறுவிக்கொள்கிறோம். அதனால் பெரும்பாலும் நாம் இதில் Windows Authentication ஐத் தேர்வு செய்யலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
SQLServer<br />
Authentication கொடுத்தால் ஒவ்வொரு முறையும் கடவுச்சொல்லைக்கொடுத்து உள்<br />
நுழையவேண்டி வரும். அல்லது அதை சேமித்து வைக்கும்<br />
வசதியைப்பயன்படுத்திக்கொள்ளலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
உங்கள் Authentication எதுவாக இருக்கிறதோ அதைத் தேர்வு செய்தபிறகு, Connect ஐ அழுத்தவும்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgHNn7pZPTegRtXH5L5w9AGcdAAe11vYvDiSR-wPVeb719sTMBnyAhwZg4d3s4G6qKzlHSqyG25Iq8de-4wwqyiKkUCnNC9OEwNmzJUyZQXx9tlYA5ZhBad2_waa1099Q7BWnFQ-FTVhLIL/s1600-h/connect.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgHNn7pZPTegRtXH5L5w9AGcdAAe11vYvDiSR-wPVeb719sTMBnyAhwZg4d3s4G6qKzlHSqyG25Iq8de-4wwqyiKkUCnNC9OEwNmzJUyZQXx9tlYA5ZhBad2_waa1099Q7BWnFQ-FTVhLIL/s320/connect.png" style="border-width: 0px; height: 237px; margin: 0px; padding: 0px; width: 320px;" /></a><br />
வாயிலாக இறக்கிக்கொண்டு நிறுவிக்கொள்ளவும். எல்லா Database களுமே அவற்றின்<br />
கட்டமைப்பில் கிட்டத்தட்ட சமானமாகவே இருக்கின்றன. சொடுக்கவும்.திரையில் Object Explorer என்னும் ஒரு Window தெரியும்.<br />
<br style="margin: 0px; padding: 0px;" />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicGDoGzJOwZIUazMCRjFWexftVig_2bC7h8Tk9JIGmEeZj0VghhaSvJZk1nlylW5OuEeNs1QqD_9G06gJESpHwRPvcRahbZRsN9Q9VhZQa9deB49Vxs6KoTOwe8mvW6wP1Ru0yvJ5kIHTs/s1600-h/objectexplorer.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicGDoGzJOwZIUazMCRjFWexftVig_2bC7h8Tk9JIGmEeZj0VghhaSvJZk1nlylW5OuEeNs1QqD_9G06gJESpHwRPvcRahbZRsN9Q9VhZQa9deB49Vxs6KoTOwe8mvW6wP1Ru0yvJ5kIHTs/s320/objectexplorer.png" style="border-width: 0px; height: 184px; margin: 0px; padding: 0px; width: 320px;" /></a><br />
அதில் Databaseல் Right Click செய்து New Database ஐ click செய்யவும்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhHTnVjru6VIoKA6nXcJRq1USVwIDfLbkbMaIVA46HhOuBKABW2_etlft5O3MJVKgty-8n5Ix_wG-tfCV4UPoDzOrjuHN_vq8qpr8gqAU1bin8BWZgjAYkmbG2GMvrhDWfnXtXuiYs6Zb6A/s1600-h/newdatabase.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhHTnVjru6VIoKA6nXcJRq1USVwIDfLbkbMaIVA46HhOuBKABW2_etlft5O3MJVKgty-8n5Ix_wG-tfCV4UPoDzOrjuHN_vq8qpr8gqAU1bin8BWZgjAYkmbG2GMvrhDWfnXtXuiYs6Zb6A/s320/newdatabase.png" style="border-width: 0px; height: 109px; margin: 0px; padding: 0px; width: 191px;" /></a><br />
புதியசட்டத்தில்<br />
Databaseக்கான பெயர் கொடுக்கவும். நான் Test எனக்கொடுத்துள்ளேன். பிறகு OK<br />
கொடுத்தால் Test என்கிற பெயரில் ஒரு Databaseஉருவாகிவிடும்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEib9gSY5RJ1o_nTTp-DznuQNpNQf6u4Z9AtcwleGDtkpTuTOv5wEcMVAla2LuTkO47J_6Ubpq-ICcgPadHh7HtlZ8HUTwFLOGqH0YcMtN54Ad094CzHsbrta64Vr9AV633PEWjAseMTxUlt/s1600-h/databasename.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEib9gSY5RJ1o_nTTp-DznuQNpNQf6u4Z9AtcwleGDtkpTuTOv5wEcMVAla2LuTkO47J_6Ubpq-ICcgPadHh7HtlZ8HUTwFLOGqH0YcMtN54Ad094CzHsbrta64Vr9AV633PEWjAseMTxUlt/s320/databasename.png" style="border-width: 0px; height: 128px; margin: 0px; padding: 0px; width: 320px;" /></a><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjLGKirhtpjTrmqYeRcCw3sJU_k9jrZIdwOlJCewTEedMmYnToW_TIYSl-l43VIXQ79EwTP8Ov10P2LB8cg-f7Y9_jEtkrf8Ysj_Uy1XRJPnAQW1P37SlX4uWBcaauXw8j5zNaxA7Wrp8Z5/s1600-h/databaseexpand.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjLGKirhtpjTrmqYeRcCw3sJU_k9jrZIdwOlJCewTEedMmYnToW_TIYSl-l43VIXQ79EwTP8Ov10P2LB8cg-f7Y9_jEtkrf8Ysj_Uy1XRJPnAQW1P37SlX4uWBcaauXw8j5zNaxA7Wrp8Z5/s320/databaseexpand.png" style="border-width: 0px; height: 293px; margin: 0px; padding: 0px; width: 319px;" /></a>Testஎன்கிற<br />
இடத்தில் இருக்கும் + Expand ஐ அழுத்தினால் அதில் DatabaseDiagrams,<br />
Tables, Views, Synonyms, Programmability, Service Broker,Storage,<br />
Security எனப் பல இருக்கும்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEidFzt3B34jTCj26rj0JrRAPOpdI7chEC0_Rqpo-4KcHHnU8l3gATZv6jFE6txbOIGIqJJxvfpP6_SDRmWdcXMR6d1NV8W4SDykazPzoB9Vxyt9owKqy0dxZ8D9q5oR1z0GxrRacLHiSxec/s1600-h/dbexpa.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEidFzt3B34jTCj26rj0JrRAPOpdI7chEC0_Rqpo-4KcHHnU8l3gATZv6jFE6txbOIGIqJJxvfpP6_SDRmWdcXMR6d1NV8W4SDykazPzoB9Vxyt9owKqy0dxZ8D9q5oR1z0GxrRacLHiSxec/s320/dbexpa.png" style="border-width: 0px; height: 320px; margin: 0px; padding: 0px; width: 251px;" /></a>அதில்Table<br />
ல் வைத்து Right click செய்து New Table ஐத் தேர்ந்தெடுக்கவும்.இதில்<br />
Column Name, Data Type, Allow Nulls ஆகியவை இருக்கும். உங்கள்Tableன்<br />
Sturctureக்குத் தகுந்தாற்போல ஒவ்வொரு Column களையும்கொடுக்கவும்.<br />
Person#, Name, City என மூன்று Columnகள்<br />
உதாரணத்திற்குக்கொடுத்திருக்கிறேன்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh6g42zSMdYt2MKU2J5dDyzRUKG1uMes8W61etqZzTi9p00phnU7zSI6QhaR3S9qd_gMOBUY_7raUX1PjqK8gp41qQND86OoVbjZUiI8sEg7ZarHz1FKHNMo8liMwf6SbeUUzomVWp6rX3R/s1600-h/structureentry.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh6g42zSMdYt2MKU2J5dDyzRUKG1uMes8W61etqZzTi9p00phnU7zSI6QhaR3S9qd_gMOBUY_7raUX1PjqK8gp41qQND86OoVbjZUiI8sEg7ZarHz1FKHNMo8liMwf6SbeUUzomVWp6rX3R/s320/structureentry.png" style="border-width: 0px; height: 115px; margin: 0px; padding: 0px; width: 320px;" /></a>பின் இதை Save செய்வதற்கு, Ctrl + S வழமை போலக் கொடுத்து Table க்காக ஒரு பெயர் சூட்டுங்கள். (MyList எனக் கொடுத்துள்ளேன்)<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgJsX7l6hSD2_uemtq94ObuxXlYeI9rrg126puG9PpNUTEKxmM9B-re1nJUBoRmjHiLdvi93hLTyvq84xSf1fAmgkHLQpQSVZG9mf_X8lCrw8YUoFlGNpbFNmDPbP93YhG2vzbYVwddvKHw/s1600-h/tablesave.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgJsX7l6hSD2_uemtq94ObuxXlYeI9rrg126puG9PpNUTEKxmM9B-re1nJUBoRmjHiLdvi93hLTyvq84xSf1fAmgkHLQpQSVZG9mf_X8lCrw8YUoFlGNpbFNmDPbP93YhG2vzbYVwddvKHw/s320/tablesave.png" style="border-width: 0px; height: 114px; margin: 0px; padding: 0px; width: 320px;" /></a>பிறகு இதை Close செய்யலாம். இப்போது உங்கள் Tableன் Structure ஆனது Save செய்யப்பட்டுவிட்டது.<br />
<br style="margin: 0px; padding: 0px;" />
இப்படி உருவாக்கிய Tableல் நமது தகவல்களை ஏற்றுவது எப்படி?<br />
Tables க்கு அருகில் இருக்கும் + அடையாளத்தைச் சொடுக்கி expand செய்தால், dbo.MyList ஐக் காணலாம்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgDcz2iQ_A8ffKH2qZ90JH1B651_lKhafI78FL61l2Szd6T69lVCi3jGGrq2h4WuOOsmp0BH8qcjGuigSwZeHuwhVXCAPvm9F1EZ3eIepkGmUD9Wj6pVwF67wZc_In3QdicHbo4Z-lBtB4f/s1600-h/tableexpand.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgDcz2iQ_A8ffKH2qZ90JH1B651_lKhafI78FL61l2Szd6T69lVCi3jGGrq2h4WuOOsmp0BH8qcjGuigSwZeHuwhVXCAPvm9F1EZ3eIepkGmUD9Wj6pVwF67wZc_In3QdicHbo4Z-lBtB4f/s320/tableexpand.png" style="border-width: 0px; height: 88px; margin: 0px; padding: 0px; width: 214px;" /></a>&nbsp;அதில் Right Click செய்து, Open Table ஐத் தேர்ந்தெடுக்கவும்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjT2qYV9VMC-RgxFzi9toqo9Z3ILNOW-7U7VNhzCDqc_WE0dwA9KEyWAbvcg8PkoaQP-CLgRG_udAlFl4KUWWMIHfd4yAytcf4t0WLxRpvyP4Licpbm3KK4yNkkjfR33bo0FxEBFOA0isJd/s1600-h/opentable.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjT2qYV9VMC-RgxFzi9toqo9Z3ILNOW-7U7VNhzCDqc_WE0dwA9KEyWAbvcg8PkoaQP-CLgRG_udAlFl4KUWWMIHfd4yAytcf4t0WLxRpvyP4Licpbm3KK4yNkkjfR33bo0FxEBFOA0isJd/s320/opentable.png" style="border-width: 0px; height: 231px; margin: 0px; padding: 0px; width: 211px;" /></a>பிறகு அதில் ஒவ்வொரு Row வாகத் தகவல்களை உள்ளீடு செய்யலாம். நான் 5 rowக்களை இதில் ஏற்றிவிட்டேன்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiqDoTBvzxlGxJMhwqXJXwEi5Qa9vsvw_hBQ4zW0Ai4nad5Z7pAqnbqrG9c7aUeFzd-Lzsm7vHX4aYJ-5dzm4OqILf8MywbgXrgwvag9yYqrGvIkIx6BeVAmxVIWBdzA5_mLDMMg81qEKt5/s1600-h/dataentry.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiqDoTBvzxlGxJMhwqXJXwEi5Qa9vsvw_hBQ4zW0Ai4nad5Z7pAqnbqrG9c7aUeFzd-Lzsm7vHX4aYJ-5dzm4OqILf8MywbgXrgwvag9yYqrGvIkIx6BeVAmxVIWBdzA5_mLDMMg81qEKt5/s320/dataentry.png" style="border-width: 0px; height: 56px; margin: 0px; padding: 0px; width: 320px;" /></a><br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh7R85LHJC-Qn7AJBMAgkF0hrOipOiz8RjCxgCl_CApShQak89IJmaJMJsZDh6xIG5qZjNLG1QKSU-OpQi2o8q34k9DNIcBZLO5-GZgV9NPysRwGOUBZWOOmASh_M6qdF3zSVeQkcT9dIO2/s1600-h/rowentry.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh7R85LHJC-Qn7AJBMAgkF0hrOipOiz8RjCxgCl_CApShQak89IJmaJMJsZDh6xIG5qZjNLG1QKSU-OpQi2o8q34k9DNIcBZLO5-GZgV9NPysRwGOUBZWOOmASh_M6qdF3zSVeQkcT9dIO2/s320/rowentry.png" style="border-width: 0px; height: 138px; margin: 0px; padding: 0px; width: 320px;" /></a><br />
பதிந்தது போதும் என நினைக்கும்போது அந்த tab ல் வலது க்ளிக் செய்து Close அழுத்திவிடலாம்.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicSbD2mH7Le4dkMPsfckxH9l4D3-9eNGfDEOTcgYhCkB1tq5LTJVfhzEaFNF_eszKtAL1pevcjxfNyyV07A-vODVJQkhdzma3VWTbfpKczLsZnQPgVt-Jzc8UD0cAXHrVdAokefXLjb_1M/s1600-h/closetable.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicSbD2mH7Le4dkMPsfckxH9l4D3-9eNGfDEOTcgYhCkB1tq5LTJVfhzEaFNF_eszKtAL1pevcjxfNyyV07A-vODVJQkhdzma3VWTbfpKczLsZnQPgVt-Jzc8UD0cAXHrVdAokefXLjb_1M/s320/closetable.png" style="border-width: 0px; height: 126px; margin: 0px; padding: 0px; width: 249px;" /></a>இதுவரையில்இங்கே<br />
நாம் GUI எனப்படும் Graphical User Interface வாயிலாக ஒருDatabaseம்,<br />
அதில் ஒரு Tableம் உருவாக்கி, அதில் புதிய தகவல்களை எப்படிப்பதிவது<br />
என்றும் கண்டோம்.</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/4748888094657262464/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-5.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4748888094657262464'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4748888094657262464'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-5.html' title=' எளிய தமிழில் SQL - பாகம் 5'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgHNn7pZPTegRtXH5L5w9AGcdAAe11vYvDiSR-wPVeb719sTMBnyAhwZg4d3s4G6qKzlHSqyG25Iq8de-4wwqyiKkUCnNC9OEwNmzJUyZQXx9tlYA5ZhBad2_waa1099Q7BWnFQ-FTVhLIL/s72-c/connect.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-4593039310525239392</id><published>2013-08-08T04:29:00.006-07:00</published><updated>2013-08-08T04:42:42.028-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 4</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<br />
<div class="post row1 post--72438" id="p72438" style="background-color: #e5f1f9; border: 1px dashed rgb(3, 114, 190); font-family: SooriyanDotCom; font-size: 12px; line-height: 14px; margin: 20px 0px 4px; padding: 3px; text-shadow: rgb(255, 255, 255) 1px 0px 1px; z-index: 1;">
<div class="inner" style="margin: 0px; padding: 0px;">
<div class="postbody" style="clear: both; color: #141a87; float: left; line-height: 1.48em; margin: 0px; padding: 0px; width: 954.4375px;">
<div class="content clearfix" style="clear: left; font-family: SooriyanDotCom, Sooriyan, Arial, Tahoma; line-height: 1.4em; margin: 0px; min-height: 3em; overflow: hidden; padding: 0px;">
<div style="margin: 0px; padding: 0px;">
<strong style="margin: 0px; padding: 0px;">ஒரு Tableன் Structure எப்படி இருக்கும்?</strong><br />
<br style="margin: 0px; padding: 0px;" />
Column Name, Data Type(Width), Allow Nulls இவைகள் அனைத்தும் அடங்கியது<br />
ஒரு Table Structure.<br />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhKyVfusMUykIU3t3oOSjXn6e-pBdIp42ivv6oNF_GrNduqn0GiiQT6ZDP3it0hWRHe5M4GqrxKJYiNOjEglK5V0tEuNfsOhpHHlODRz_6iXCvCHdrR-prgAh3w-5Fq8Pw7R48x4ttKYrNh/s1600-h/tablestructure.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhKyVfusMUykIU3t3oOSjXn6e-pBdIp42ivv6oNF_GrNduqn0GiiQT6ZDP3it0hWRHe5M4GqrxKJYiNOjEglK5V0tEuNfsOhpHHlODRz_6iXCvCHdrR-prgAh3w-5Fq8Pw7R48x4ttKYrNh/s320/tablestructure.png" style="border-width: 0px; height: 194px; margin: 0px; padding: 0px; width: 320px;" /></a><br />
<br style="margin: 0px; padding: 0px;" />
AllowNull<br />
என்பது tick செய்யப்பட்டிருந்தால், அதன் மதிப்பை உள்ளீடுசெய்யும்போது<br />
வெறுமனே விட்டுவிடலாம் என்று அர்த்தம். தற்சமயம் அதன்மதிப்பு நமக்குத்<br />
தெரிந்திருக்கவில்லை. பிறகு சில காலம் கழித்துக் கூடஅதன் மதிப்பை நாம்<br />
உள்ளிட்டுக் கொள்ளலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
Allow Null என்பது tickசெய்யப்படாமல்<br />
இருந்தால், அந்தக் குறிப்பிட்ட columnன் தகவலைக் கண்டிப்பாகநாம் கொடுத்தே<br />
தீரவேண்டும். அதன் மதிப்பை உள்ளிடாமல் விட்டுவிட்டால்பிழைச்செய்தி வரும்.<br />
ஆனால் Identity Columnக்கு மட்டும் ஒரு விதிவிலக்குஉண்டு.<br />
<br style="margin: 0px; padding: 0px;" />
முதல் Column ஆகிய AddressID ன் ஆரம்பத்தில் ஒரு சிறிய சாவியின் படம்<br />
&nbsp;போடப்பட்டுள்ளது. அது இந்த Tableன் primary key ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgB83QV3sIDZKrBf9HRU5zv_LSTOIpF0J92jZ-VSPNqVtoPCf6kaam8mPXlI8rJjDsxwc_Te8sfUpRKMV6msuQh0ZVudLMz-7IVJiUnILNjuV_8mchyKA9Qm7kiShn_FsKEBZHtPrIxyQWH/s1600-h/primary.png" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgB83QV3sIDZKrBf9HRU5zv_LSTOIpF0J92jZ-VSPNqVtoPCf6kaam8mPXlI8rJjDsxwc_Te8sfUpRKMV6msuQh0ZVudLMz-7IVJiUnILNjuV_8mchyKA9Qm7kiShn_FsKEBZHtPrIxyQWH/s320/primary.png" style="border-width: 0px; height: 157px; margin: 0px; padding: 0px; width: 320px;" /></a><br />
<br style="margin: 0px; padding: 0px;" />
Primarykey<br />
ஆனது ஒரு குறிப்பிட்ட Row வை தனித்து அடையாளம் கண்டுகொள்ள உதவும்.மேலும்<br />
AddressID ஆனது Identity Column ஆகவும் குறிப்பிடப்பட்டுள்ளதால்,இதன்<br />
மதிப்பை நாம் நேரடியாக உள்ளிட வேண்டிய அவசியமில்லை.<br />
Databaseல்தானியங்கியாக அடுத்தடுத்த எண்களை இந்த AddressIDல் Input<br />
செய்துவிடும்.<br />
<br style="margin: 0px; padding: 0px;" />
மேலேஉள்ள Table Structureல் AddressLine2 க்கு<br />
மட்டும் Allow Nulls ஆனது tickசெய்யப்பட்டு இருக்கிறது. ஆகவே<br />
AddressLine2க்கு உரிய தகவல் நம்மிடம்தற்சமயம் இல்லையென்றால் அதை நாம்<br />
உள்ளீடு செய்யாமல் அப்படியே விட்டுவிட்டுஅடுத்த Columnக்கு உரிய தகவலை<br />
உள்ளீடு செய்யலாம். பிறகு எப்போதுவேண்டுமானாலும் AddressLine2க்கு உரிய<br />
Dataவைக் கொடுக்கலாம். பிழைச்செய்திஎதுவும் வராது.<br />
<br style="margin: 0px; padding: 0px;" />
rowguid என்பதற்கு நேராக uniqueidentifier என Data Type இருக்கிறது.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">அது என்ன Unique Identifier?</strong><br />
<br style="margin: 0px; padding: 0px;" />
8DD27D89-6AE7-4316-B3B8-0CCEF0924F60 இது போன்ற ஒரு hexadecimal மதிப்பு.<br />
இதுஒவ்வொரு<br />
முறையும் வேறு வேறு மதிப்புகளைக் கொடுக்கும். கணினிக்குக்<br />
கணினிவித்தியாசமான மதிப்பையும், ஒரே கணினியில் ஒவ்வொரு முறையும்<br />
இயக்கும்போதுவேறு வேறு மதிப்புகளைக் கொடுக்கும்.<br />
<br style="margin: 0px; padding: 0px;" />
நாம் இந்த Unique<br />
IdentifierData Type ஐக் கொண்ட Column க்கு எந்த தகவலையும் உள்ளீடு<br />
செய்யவேண்டாம்.இது தானியங்கியாக கணினியே உருவாக்கும் ஒரு மதிப்பாகும்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒவ்வொரு row வையும் பிரித்துக் காட்ட UniqueIdentifierஐப் பயன்படுத்தலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
உதாரணம் :<br />
<br style="margin: 0px; padding: 0px;" />
declare @a uniqueidentifier<br />
set @a = newid()<br />
print @a<br />
<br style="margin: 0px; padding: 0px;" />
இதன் விடை.<br />
<br style="margin: 0px; padding: 0px;" />
F94771ED-8405-4C30-893E-0325FA0A394C<br />
<br style="margin: 0px; padding: 0px;" />
மேலே கொடுத்துள்ள ஒரு சிறிய நிரல் ஆனது T-SQL programming ல் எழுதப்பட்டது.<br />
<br style="margin: 0px; padding: 0px;" />
T-SQL என்றால் Transact SQL என்ற விரிவைக் கொண்டது. இது ஒரு கணினி மொழி.<br />
<br style="margin: 0px; padding: 0px;" />
மேலே @a என்பது ஒரு variable. இதன் மதிப்பு ஒவ்வொரு முறையும் மாறிக்கொண்டே இருக்கும்.<br />
<br style="margin: 0px; padding: 0px;" />
set@a<br />
= newid() ---&gt; என்றால் ஒரு கணினியால் அந்த நேரத்தில்உருவாக்கப்பட்ட<br />
ஒரு புதிய hexadecimal based மதிப்பை அந்த variable @a ல்பதிகிறோம்.<br />
<br style="margin: 0px; padding: 0px;" />
print<br />
@a --&gt; திரையில் @a என்பதன் மதிப்பைக் காண்பி.உடனே திரையில் தெரியும்<br />
மதிப்பானது F94771ED-8405-4C30-893E-0325FA0A394Cஇப்படி இருக்கலாம்.<br />
எனக்கு இந்த மதிப்பு வந்தது. உங்களுக்கு வேறு மதிப்புவரும்.<br />
ஒவ்வொருவருக்கும் வேறுவேறு மதிப்புகளை இந்த நிரல் உருவாக்கித்தரும்.<br />
<br style="margin: 0px; padding: 0px;" />
AddressLine1, AddressLine2, City, PostalCode ஆகிய Columnகளின்<br />
&nbsp;DataType ஆனது nVarchar வகையைச் சேர்ந்தது.<br />
<br style="margin: 0px; padding: 0px;" />
அதாவது இந்த Columnகளில் நாம் unicode வகையைச் சேர்ந்த எண்கள்,<br />
எழுத்துக்கள், பிற அடையாளங்கள் ஆகியவற்றை உள்ளிடலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
AddressLine1க்காக<br />
நாம் அதிகபட்சமாக 60 எழுத்துக்களை ஒதுக்கியுள்ளோம். ஆனால் நாம்<br />
20எழுத்துக்களை மட்டுமே உள்ளிட்டால், மீதியுள்ள 40 காலியிடங்கள்<br />
trimசெய்யப்பட்டு 20 எழுத்துக்கள் மாத்திரமே table ல் பதிவாகும்.<br />
இதுவேvarcharன் சிறப்பு.<br />
<br style="margin: 0px; padding: 0px;" />
இதுவே char என இருந்தால் ஒட்டுமொத்தமாக நாம் எவ்வளவு<br />
&nbsp;எழுத்துக்களை ஏற்கனவே ஒதுக்கியுள்ளோமோ அத்தனை இடங்களுமே வீணடிக்கப்பட்டுவிடும்.<br />
<br style="margin: 0px; padding: 0px;" />
AddressID,StateProvinceID<br />
இவையிரண்டின் DataType ஆனது int வகையைச் சேர்ந்தது.அதனால் இந்த<br />
இரண்டுக்கும் நாம் எண்களை உள்ளீடு செய்யலாம். ஆனால் AddressIDஆனது<br />
Identity Column வகையைச் சேர்ந்ததால் (அது auto incrementவகைப்பட்டது)<br />
அதற்குத் தகவலை உள்ளிட வேண்டாம். StateProviceIDக்கு மட்டும்அதற்குரிய<br />
எண்ணைப் பதிவிட்டால் போதும்.<br />
<br style="margin: 0px; padding: 0px;" />
Modified Date என்பதில்அதற்குரிய<br />
DataType ஆனது DateTime ஆகக் குறிப்பிடப்பட்டுள்ளது.அதனால் அந்தModified<br />
Date க்கு உரிய columnன் மதிப்பில் ஒரு குறிப்பிட்ட தேதியைஉள்ளிடவேண்டும்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு சிறிய T-SQL நிரல்.<br />
<br style="margin: 0px; padding: 0px;" />
declare @a datetime<br />
set @a = getdate()<br />
print @a<br />
<br style="margin: 0px; padding: 0px;" />
@a என்பது datetime எனப்படும் DataTypeஐச் சேர்ந்தது.<br />
getdate() எனப்படும் ஒரு function நடப்புத் தேதியையும், நேரத்தையும் தரவல்லது.<br />
<br style="margin: 0px; padding: 0px;" />
print @a என்றவுடன் கிடைத்த விடை.<br />
Jan 26 2009 11:00AM<br />
<br style="margin: 0px; padding: 0px;" />
இங்கேஒரு<br />
சில இடங்களில் புதியவர்களுக்காக சில குறிப்பிட்ட பதங்களை<br />
ஒவ்வொருமுறையும்<br />
விளக்கியிருப்பேன். Primary key, Identity Column போன்றவற்றைமீண்டும்<br />
சுருக்கமாகக் கூறியிருப்பேன். ஒரு புரிதலுக்காகத்தான் அவ்வாறுமீண்டும்<br />
கூறியிருக்கிறேனே தவிர வேறெதுவும் இல்லை. இதற்கு முன்னர்வெளியிட்ட 3<br />
பதிவுகளில் அவற்றை விளக்கியிருந்தாலும், அதே பதங்களை<br />
&nbsp;இங்கே4வது பதிவுகளில்<br />
பயன்படுத்தும்போது புரியாமல் போகிவிடக்கூடாது<br />
மீண்டும்குறுவிளக்கமாகக்<br />
குறிப்பிட்டிருக்கிறேன்.</div>
</div>
</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/4593039310525239392/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-4.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4593039310525239392'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4593039310525239392'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-4.html' title='எளிய தமிழில் SQL - பாகம் 4'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhKyVfusMUykIU3t3oOSjXn6e-pBdIp42ivv6oNF_GrNduqn0GiiQT6ZDP3it0hWRHe5M4GqrxKJYiNOjEglK5V0tEuNfsOhpHHlODRz_6iXCvCHdrR-prgAh3w-5Fq8Pw7R48x4ttKYrNh/s72-c/tablestructure.png" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-6950193157197727775</id><published>2013-08-08T04:29:00.000-07:00</published><updated>2013-08-08T04:45:07.707-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 3</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<strong style="color: #141a87; font-family: SooriyanDotCom, Sooriyan, Arial, Tahoma; line-height: 1.4em; margin: 0px; padding: 0px;">Identity Column என்றால் என்ன?</strong><br />
<div class="post row2 post--70066" id="p70066" style="background-color: #e5f1f9; border: 1px dashed rgb(3, 114, 190); font-family: SooriyanDotCom; font-size: 12px; line-height: 14px; margin: 20px 0px 4px; padding: 3px; text-shadow: rgb(255, 255, 255) 1px 0px 1px; z-index: 1;">
<div class="inner" style="margin: 0px; padding: 0px;">
<div class="postbody" style="clear: both; color: #141a87; float: left; line-height: 1.48em; margin: 0px; padding: 0px; width: 954.4375px;">
<div class="content clearfix" style="clear: left; font-family: SooriyanDotCom, Sooriyan, Arial, Tahoma; line-height: 1.4em; margin: 0px; min-height: 3em; overflow: hidden; padding: 0px;">
<div style="margin: 0px; padding: 0px;">
<br style="margin: 0px; padding: 0px;" />
<div align="justify" style="margin: 0px; padding: 0px;">
ஒருகுறிப்பிட்ட<br />
Column ன் மதிப்பானது, அதற்குரிய மதிப்பை நாம் கொடுக்காமலேயே,அதுவாகவே<br />
தானியங்கித்தனமாக உயர்ந்துகொண்டு வருவதை Auto Increment எனலாம்.இப்படி ஒரு<br />
Column ன் மதிப்பை தானாக உயர்த்துவதால், இந்த Column க்குIdentity Column<br />
என்போம்.</div>
<br style="margin: 0px; padding: 0px;" />
<br style="margin: 0px; padding: 0px;" />
<div align="justify" style="margin: 0px; padding: 0px;">
இந்த<br />
Column ன் Data Type ஆனது numericஆக இருத்தல் வேண்டும். இதன் உயர்வு<br />
விகிதம் (Identity Increment), எந்தஎண்ணிக்கையில் இருந்து<br />
ஆரம்பிக்கவேண்டும் (Identity Seed) போன்றவற்றை நாமேதீர்மாணிக்கலாம்.</div>
<br style="margin: 0px; padding: 0px;" />
<br style="margin: 0px; padding: 0px;" />
<div align="justify" style="margin: 0px; padding: 0px;">
ஒவ்வொரு<br />
Rowக்கும், இந்த குறிப்பிட்ட IdentityColumn ன் மதிப்பு அதுவாகவே<br />
உயர்ந்துகொண்டிருக்கும். அடுத்தடுத்தRowக்களின் தகவல்களை உள்ளீடு<br />
செய்யும்போது, இந்த Identity Columnன்மதிப்பை நாம் உள்ளீடு செய்யத்<br />
தேவையில்லை.</div>
<br style="margin: 0px; padding: 0px;" />
<br style="margin: 0px; padding: 0px;" />
Primary key என்பது என்னவென்று இதற்கு முந்தைய பதிவில் பார்த்தோம்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Foreign Key என்றால் என்ன?</strong><br />
<br style="margin: 0px; padding: 0px;" />
<div align="justify" style="margin: 0px; padding: 0px;">
Tableஎன்றால்<br />
என்னவென்று நமக்குத் தெரியும். அதில் பல தகவல்களை ஒவ்வொரு Rowவாகஉள்ளீடு<br />
செய்து வைத்திருப்போம். ஒன்றுக்கு மேற்பட்ட Tableகளில் இருக்கும்தகவல்களை<br />
ஒரே திரையில் காண்பதற்கு உதவுவதே Foreign key ஆகும்.</div>
<br style="margin: 0px; padding: 0px;" />
<br style="margin: 0px; padding: 0px;" />
ஒரு குறிப்பிட்ட Table ல் ஒவ்வொரு Rowவையும் பிரித்துத் தனிமைப்படுத்துவதற்கு,<br />
அடையாளம் காண்பதற்கு Primary key உதவுகிறது.<br />
<br style="margin: 0px; padding: 0px;" />
இந்தக் கட்டுமானத்தை Master - Detail என்று கூறுவோம்.<br />
<div align="justify" style="margin: 0px; padding: 0px;">
MasterTableல்<br />
ஒரு குறிப்பிட்ட Column ஆனது Primary key ஆக இருக்கும். (இதுமுதலாவது<br />
Table). Primary key ன் மதிப்பு ஒவ்வொரு Rowக்கும் மாறிக்கொண்டேஇருக்கும்.<br />
உதாரணமாக Person#. ஒவ்வொரு நபருக்கும் ஒரு தனிப்பட்ட எண்ணைக்கொண்டு<br />
வித்தியாசப்படுத்துவதற்கு Primary key உதவும்.</div>
<br style="margin: 0px; padding: 0px;" />
<br style="margin: 0px; padding: 0px;" />
Master<br />
Tableல் ஒரு முறை மட்டும் வந்த Person# ஆனது, Detail Table ல் பலமுறை<br />
திரும்பத்திரும்ப வரும். இந்த இரண்டு எண்ணும் ஒரே எண்ணாக இருக்கும்.<br />
இரண்டின் Data Type ம் ஒன்றாகவே இருக்கும். இரண்டும் ஒன்றுக்கொன்று<br />
தொடர்புடையதாக இருக்கும்.<br />
<br style="margin: 0px; padding: 0px;" />
இந்த Primary - Foreign key மூலம் இரண்டு Tableகளின் மதிப்புகளை<br />
ஒரே திரையில் காணலாம்.<br />
இதை join என்போம்.<br />
<br style="margin: 0px; padding: 0px;" />
இந்த இரண்டு keyகளின் Columnல் ஏற்றப்பட்ட மதிப்புகளை<br />
&nbsp;அடையாளப்படுத்தியே Master-Detail Table மையப்படுத்தப்படுகிறது.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Unique என்றால் என்ன?</strong><br />
ஒரு குறிப்பிட்ட Columnல் உள்ள மதிப்பு ஒவ்வொரு Rowக்கும் வித்தியாசமானதாக<br />
இருப்பதை Unique எனலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
Person#எனப்படுவதை<br />
Unique Column எனலாம். ஒவ்வொரு நபரின் பெயரும் வித்தியாசமானதாகஇருக்கத்<br />
தேவையில்லை (காரணம் : பெயர்ப் பற்றாக்குறை). ஆனால் ஒவ்வொருநபருக்கும் நாம்<br />
அளிக்கும் குறிப்பிட்ட எண் (Person#) ஆனது Unique ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
ஆகவேPrimary<br />
key ஆனது Unique தான். ஆனால் Primary keyஆனது NULL ஆக இருக்கவேமுடியாது.<br />
Unique Column ஆனது ஒரே ஒருமுறை மட்டும், NULL மதிப்பைஏற்றுக்கொள்ளும்.<br />
இதுவே இவை இரண்டுக்கும் உள்ள ஒரே வித்தியாசம்.<br />
<br style="margin: 0px; padding: 0px;" />
NULL என்பது எந்த மதிப்பும் இல்லாதது. அதன் மதிப்பு பூஜ்யமோ / எதோ<br />
ஒரு எழுத்தோ / எழுத்துத் தொகுப்போ இல்லை. அது மதிப்பே இல்லாதது.<br />
<br style="margin: 0px; padding: 0px;" />
Primary key ஆனது NULL ஐ ஏற்றுக்கொள்ளாது. ஆனால் Unique Column ஆனது<br />
&nbsp;ஒரே ஒருமுறை மட்டும் NULLஐ ஏற்றுக்கொள்ளூம்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">DataType களின் வகைகள் யாவை?</strong><br />
SQL Server 2005ல் நாம் பயன்படுத்தும் Data Typesகளின் வகைகள் கீழே:<br />
<br style="margin: 0px; padding: 0px;" />
user-defined data types (highest)<br />
sql_variant<br />
xml<br />
datetime<br />
smalldatetime<br />
float<br />
real<br />
decimal<br />
money<br />
smallmoney<br />
bigint<br />
int<br />
smallint<br />
tinyint<br />
bit<br />
ntext<br />
text<br />
image<br />
timestamp<br />
uniqueidentifier<br />
nvarchar<br />
nchar<br />
varchar<br />
char<br />
varbinary<br />
binary (lowest)<br />
<br style="margin: 0px; padding: 0px;" />
DataTypes<br />
என்பது, ஒவ்வொரு Columnலும் நாம் உள்ளீடு செய்யப்போகும் தகவலின்<br />
வகையைக்&nbsp;<span style="line-height: 1.4em;">குறிக்கிறது.எண், எழுத்து, தேதி - போன்ற Data Type ஐ நாம்</span><br />
அதிகம்பயன்படுத்துவோம்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Character க்கும் Variable Characterக்கும் என்ன வித்தியாசம்?</strong><br />
<br style="margin: 0px; padding: 0px;" />
NAMECHARACTER(50)<br />
---&gt; இது ஒரு Column எனக் கொண்டால், இதில் Field nameஆனது NAME ஆகும்.<br />
இதில் நாம் உள்ளீடு செய்யவிருக்கிற தகவலின் வகைcharacter எனப்படும்<br />
DataType ஐச் சார்ந்தது. அதில் நாம் அதிகபட்சமாக 50தனித்தனி எழுத்துகளை<br />
(இடைவெளி Space) ஐயும் சேர்த்து உள்ளிடலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
உதாரணமாக<br />
NAME=<br />
"Raja" எனக் கொடுத்தால், இதில் 4 எழுத்துக்களை உள்ளிட்டு<br />
இருக்கிறோம்.ஆனால் அதிகபட்சமாக நாம் 50 எழுத்துக்களை உள்ளிட<br />
அனுமதிக்கிறது.அடைப்புக்குறிக்குள் இருக்கும் (50) என்பது இதைக்<br />
குறிக்கிறது.<br />
<br style="margin: 0px; padding: 0px;" />
நாம்கொடுத்துள்ள<br />
Rajaவில் 4 எழுத்துக்கள் மட்டுமே உள்ளன. ஆனால் மீதியுள்ள<br />
&nbsp;46எழுத்துக்களின்<br />
மதிப்பை நாம் உள்ளீடு செய்யாமல் விட்டுவிட்டோம். ஆனால்ஒட்டுமொத்த 50<br />
எழுத்துக்களுமே வன்வட்டு (hard disk) ல்பதிவாகும்.மீதியுள்ள 46<br />
எழுத்துக்களுக்கு Space மூலம் நிரப்பப்பட்டு அதன்ஒட்டுமொத்த 50<br />
மதிப்புகளும் வீணாக்கப்பட்டுவிடும்.<br />
<br style="margin: 0px; padding: 0px;" />
ஆனால்<br />
variablecharacter என்பதில், Babu என உள்ளிட்டால் 4 எழுத்துக்கள் மட்டுமே<br />
கணக்கில்எடுத்துக்கொள்ளப்படும். மீதியுள்ள 46 எழுத்துக்களில் இருக்கும்<br />
Spaceகணக்கில் எடுத்துக்கொள்ளப்படாமல் அவற்றின் Space<br />
எல்லாம்நிராகரிக்கப்பட்டு 4 எழுத்துக்கள் மாத்திரமே hard disk ல்<br />
எழுதப்படும்.இதனால் நம் நினைவகம் வீணாவது தவிர்க்கப்படும்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">UniCode எழுத்துக்களைப் பதிவு செய்வதற்கு எந்த Data Types ஐப்</strong><br />
<strong style="margin: 0px; padding: 0px;">&nbsp;பயன்படுத்துவது?</strong><br />
<br style="margin: 0px; padding: 0px;" />
பெரும்பாலும் ஆங்கிலத்தில் உள்ள தகவல்களை character, varchar<br />
முதலிய Data Type மூலம் உள்ளீடு செய்யலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
ஆனால் ஆங்கிலம் அல்லாத பிற மொழிகளான தமிழ், மலையாள<br />
&nbsp;மொழிகளை உள்ளீடு செய்ய நாம் nvarchar, nchar போன்ற Data Type ஐப்<br />
&nbsp;பயன்படுத்தலாம்.<br />
<br /></div>
</div>
</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/6950193157197727775/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-3.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/6950193157197727775'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/6950193157197727775'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-3.html' title='எளிய தமிழில் SQL - பாகம் 3'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-5409029595449233469</id><published>2013-08-08T04:22:00.001-07:00</published><updated>2013-08-08T04:46:21.711-07:00</updated><title type='text'> எளிய தமிழில் SQL - பாகம் 2</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<br />
<div class="post row2 post--68577" id="p68577" style="background-color: #e5f1f9; border: 1px dashed rgb(3, 114, 190); font-family: SooriyanDotCom; font-size: 12px; line-height: 14px; margin: 20px 0px 4px; padding: 3px; text-shadow: rgb(255, 255, 255) 1px 0px 1px; z-index: 1;">
<div class="inner" style="margin: 0px; padding: 0px;">
<div class="postbody" style="clear: both; color: #141a87; float: left; line-height: 1.48em; margin: 0px; padding: 0px; width: 954.4375px;">
<div class="content clearfix" style="clear: left; font-family: SooriyanDotCom, Sooriyan, Arial, Tahoma; line-height: 1.4em; margin: 0px; min-height: 3em; overflow: hidden; padding: 0px;">
<div style="margin: 0px; padding: 0px;">
<strong style="margin: 0px; padding: 0px;">RDBMS என்பது என்ன?</strong><br />
RDBMS என்பதன் விரிவு : Relational Database Management System.<br />
<br style="margin: 0px; padding: 0px;" />
SQL ஐப் பயன்படுத்தும் நவீன மென்பொருட்கள் சில :<br />
MS SQL Server, IBM DB2, Oracle, MySQL, and Microsoft Access.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Table என்பது என்ன?</strong><br />
Database ல் தகவல்களை எங்கே பதிவு செய்திருக்கிறோமோ அந்த அமைப்பு Table எனப்படும்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒன்றுக்கு ஒன்று தொடர்புடைய தகவல்களின் தொகுப்பு Table.<br />
<br style="margin: 0px; padding: 0px;" />
Table ஆனது எந்தவிதமான கட்டமைப்பில் அமைந்திருக்கும்?.<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு Table ல் பல Column / Field இருக்கும். பல Column களின் தொகுப்பே Table.<br />
<br style="margin: 0px; padding: 0px;" />
ஒவ்வொருColumn<br />
மும் ஒரு குறிப்பிட்ட வகையான தகவலைக் கையகப்படுத்தி இருக்கும்.ஆகவே<br />
ஒவ்வொரு Columnம் அதற்குரிய Data Type ஐக் கொண்டேஅனுசரிக்கப்படுகிறது.<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு Databaseல் நிறைய Tableகள் இருக்கும். பல்வேறு Tableகளின் தொகுப்பை Database எனலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh5lTwrEf3d_VbCDf2s0rovBbh0KFGZj1B_fH-5XL02k7EduvT9EmA06MBN4DJvzC-HhdF3z-Qp-YNhuRP6ZOUhmPWHUZf_McvahtXnR69r3zl671kSkqKdlR12YGXfcfvNYY2dSWPr4O8/s1600-h/table.jpg" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank"><img alt="" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh5lTwrEf3d_VbCDf2s0rovBbh0KFGZj1B_fH-5XL02k7EduvT9EmA06MBN4DJvzC-HhdF3z-Qp-YNhuRP6ZOUhmPWHUZf_McvahtXnR69r3zl671kSkqKdlR12YGXfcfvNYY2dSWPr4O8/s320/table.jpg" style="border-width: 0px; margin: 0px; padding: 0px;" /></a><br />
மேலே ஒரு Tableன் மாதிரி<br />
வடிவத்தைக் கொடுத்துள்ளேன். (படத்தின் மேல் சொடுக்கினால் பெரிதாகப் பார்க்கலாம்).<br />
<br style="margin: 0px; padding: 0px;" />
இதில் Person#,LastName,FirstName,Address,City ஆகியவற்றை Column/Field எனலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
Person# என்பது எண்களால் குறிப்பிடப்படுகிறது. இதன் Data Type ஆனது numeric.<br />
LastName,FirstName,City ஆகியவை எழுத்தால் குறிப்பிடப்படுவதால்<br />
இவற்றின் Data Type ஆனது character, variable character ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
Addressஎன்கிற<br />
Columnல் எண்ணாலும், எழுத்தாலும் குறிப்பிடப்பட்டாலும் இதுcharacter<br />
அல்லது variable character என்கிற வகைக்குள்ளேயே வைத்து விடலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
PinCodeஎன்று<br />
ஒரு column இருந்தால் அதையும் Character வகைக்குள்ளே<br />
வைத்துவிடலாம்.PinCode பயன்படுத்தி நாம் எந்தவிதமான<br />
கூட்டல்,கழித்தல்,வகுத்தல்,பெருக்கல்முதலிய கணக்கீடுகளைச்<br />
செய்யப்போவதில்லை. அதனால் அதை numeric வகைக்குள்வைப்பதற்குப் பதிலாக<br />
character வகைக்குள்ளேயே வைத்துவிடலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">ஒரு Table ல் Row அல்லது Tuple என்றால் என்ன?</strong><br />
மேலே உள்ள Table ல் மொத்தம் 3 row க்கள் இருக்கின்றன.<br />
<br style="margin: 0px; padding: 0px;" />
முதலில் இருப்பது தலைப்பாக இருப்பதால் அதை விடுத்து, அதன்<br />
கீழ் உள்ள 3 row மட்டுமே கருத்தில் எடுத்துக்கொள்ளப்படுகின்றன.<br />
<br style="margin: 0px; padding: 0px;" />
Row என்பது Columnகளின் தொகுப்பு. ஒன்றுக்கொன்று தொடர்புடைய<br />
தகவல்களை ஒரு Row ல் எழுதி வைப்பது வழக்கம்.<br />
<br style="margin: 0px; padding: 0px;" />
உதாரணமாக : 3,Karthik,The Hero,Space, Erode : இவை அனைத்தும்<br />
&nbsp;ஒரு குறிப்பிட்ட நபரின் தகவல்களே. ஒன்றுக்கு ஒன்று தொடர்புடைய தகவல்கள்.<br />
<br style="margin: 0px; padding: 0px;" />
3 என்பது நபரின் எண்<br />
Karthik : First Name<br />
The Hero : Last Name<br />
Space : Address<br />
Erode : City<br />
<br style="margin: 0px; padding: 0px;" />
இந்தRow<br />
ல் Address பகுதி மட்டும் Space விட்டுவிட்டோம். அதாவது ஏதேனும்Columnல்<br />
நிரப்பப்பட வேண்டிய தகவல் தற்சமயத்துக்குத் தெரியவில்லையெனில்அதை<br />
நிரப்பாமல் விட்டுவிடலாம். பிறகு நிரப்பிக்கொள்ளலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
Karthikஎன்பவரின்<br />
Address தற்சமயம் நமக்குத்தெரிந்திருக்கவில்லை. அதனால் அதைஅப்படியே<br />
நிரப்பாமல் விட்டுவிட்டு, அடுத்த Field ஆகிய City ல் Erode<br />
எனஎழுதிவிட்டோம்.<br />
<br style="margin: 0px; padding: 0px;" />
இவ்வாறு ஒரு குறிப்பிட்ட Columnல்<br />
நிரப்பப்படவேண்டிய தகவலானது தற்சமயம் நிரப்பப்பட அவசியம்<br />
இல்லை என்பதை<br />
Allow Nullஎன்பதே தீர்மாணிக்கும்.<br />
<br style="margin: 0px; padding: 0px;" />
A = 0, ----&gt; இது எண் வகையைச் சேர்ந்தது (numeric)<br />
B = "Karthik" ----&gt; இது எழுத்து வகையைச் சேர்ந்தது (character)<br />
C = NULL ----&gt; தகவல் தற்சமயம் கைவசம் இல்லை (NULL)<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">NULL என்பதன் அர்த்தம்</strong>யாதெனில்,<br />
தற்போது அந்தக் குறிப்பிட்ட தகவலின் மதிப்பு எதுவும் இல்லை. அது<br />
பூஜ்யமும்<br />
இல்லை. அதில் எந்த மதிப்பும் இல்லை. அது NULL - அவ்வளவுதான்.<br />
<br style="margin: 0px; padding: 0px;" />
Allow NULL - இதன் மதிப்பை ஆமாம் (true), இல்லை (false) என்கிற கட்டுக்குள்<br />
&nbsp;கொண்டு வரலாம். true / false.<br />
<br style="margin: 0px; padding: 0px;" />
ஒவ்வொரு நபருக்கும் தனித்தனிப் பெயர் இருப்பதுபோல, இங்கே<br />
அவரவர்க்கும் தனித்தனி எண்கள் தரப்படும்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒன்றுக்கு மேற்பட்டவர்களுக்கு ஒரே பெயர்கள் இருக்கலாம் (பெயர்ப் பற்றாக்குறை!).<br />
<br style="margin: 0px; padding: 0px;" />
எனக்குKarthik<br />
என்கிற பெயர்கள் உடைய 6 நண்பர்கள் இருக்கிறார்கள்.<br />
அவர்களைவித்தியாசப்படுத்த ஒவ்வொருவருக்கும்<br />
ஒரு எண்கள் தரப்படுகின்றன.<br />
அதுவேPerson#.<br />
<br style="margin: 0px; padding: 0px;" />
இதற்கு Primary Key என்று பெயர்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">அது என்ன Primary Key?</strong><br />
<br style="margin: 0px; padding: 0px;" />
ஒன்றுக்குமேற்பட்டவர்களின்<br />
பெயர்கள் ஒரே மாதிரியாக இருக்கும்போது, ஒவ்வொருவரையும்<br />
தனித்தனியாக<br />
அடையாளம் காண்பிப்பதற்கு உதவும் மாற்று உறுப்புதான் PrimaryKey ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு Tableல் பல Rowக்கள் இருக்கலாம். ஒரு Rowல் பல Column இருக்கலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒவ்வொரு Rowவையும் மற்ற Row க்களில் இருந்து பிரித்து தனித்து<br />
அடையாளம் காண்பதற்கு Primary key பயன்படுத்துகிறோம்.<br />
<br style="margin: 0px; padding: 0px;" />
சற்றுமுன்னர்<br />
NULL பற்றிப் பார்த்தோம். ஒரு குறிப்பிட்ட தகவலின் மதிப்பு,தற்சமயம்<br />
கையில் இல்லாமல் இருந்தால் அதை NULL என்று தீர்மானித்து<br />
அப்படியேவிட்டுவிடலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">Primary key ஆனது NULL ஆக இருக்க வாய்ப்பு உள்ளதா?</strong><br />
கண்டிப்பாக இல்லை. Primary key ஆனது எந்த ஒரு சமயத்திலும் NULL<br />
ஆக இருக்கவே இருக்காது.<br />
<br /></div>
</div>
</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/5409029595449233469/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-2.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5409029595449233469'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5409029595449233469'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-2.html' title=' எளிய தமிழில் SQL - பாகம் 2'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh5lTwrEf3d_VbCDf2s0rovBbh0KFGZj1B_fH-5XL02k7EduvT9EmA06MBN4DJvzC-HhdF3z-Qp-YNhuRP6ZOUhmPWHUZf_McvahtXnR69r3zl671kSkqKdlR12YGXfcfvNYY2dSWPr4O8/s72-c/table.jpg" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-7368087358026314769</id><published>2013-08-08T04:19:00.003-07:00</published><updated>2013-08-08T04:20:48.445-07:00</updated><title type='text'>எளிய தமிழில் SQL - பாகம் 1</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<div class="post row2 post--67309" id="p67309" style="background-color: white; border: 1px dashed rgb(3, 114, 190); font-family: SooriyanDotCom; font-size: 12px; line-height: 14px; margin: 20px 0px 4px; padding: 3px; text-shadow: rgb(255, 255, 255) 1px 0px 1px; z-index: 1;">
<div class="inner" style="margin: 0px; padding: 0px;">
<div class="postbody" style="clear: both; color: #141a87; float: left; line-height: 1.48em; margin: 0px; padding: 0px; width: 954.4375px;">
<div class="content clearfix" style="clear: left; font-family: SooriyanDotCom, Sooriyan, Arial, Tahoma; line-height: 1.4em; margin: 0px; min-height: 3em; overflow: hidden; padding: 0px;">
<div style="margin: 0px; padding: 0px;">
<div style="margin: auto; padding: 0px; text-align: center; width: 954.4375px;">
<br /></div>
<strong style="margin: 0px; padding: 0px;">SQL என்பதன் விரிவு என்ன?</strong><br />
Structured Query Language<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">SQLன் பயன்கள் யாவை?</strong><br />
<br style="margin: 0px; padding: 0px;" />
Databaseன் தகவல்களைத் தேடி எடுப்பது,<br />
புதிய தகவலை ஏற்றுவதற்கு,<br />
பழைய விவரங்களை மாற்றுவதற்கு,<br />
அழிப்பதற்கு மற்றும் இன்னும் நிறைய விசயங்களுக்கு SQL பயன்படுகிறது.<br />
Database களில் இருக்கும் தகவல்களை எடுக்க / கொடுக்க SQL உதவுகிறது.<br />
<br style="margin: 0px; padding: 0px;" />
Query என்றால் கேள்வி, விசாரணை, தேடுதல் என அர்த்தம் கொள்ளலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
<br style="margin: 0px; padding: 0px;" />
சரி எடுத்த எடுப்பில் Database என ஆரம்பித்துவிட்டேன்.<br />
<strong style="margin: 0px; padding: 0px;">அது என்ன Database?</strong><br />
<br style="margin: 0px; padding: 0px;" />
பாய்ஸ்படத்தில்<br />
நடிகர் செந்தில், மணிகண்டனுடன் ஒரு கையடக்க<br />
நோட்டுப்புத்தகத்தைவைத்துக்கொண்டு ”எந்தக் கோவிலில் எந்த நேரத்தில்<br />
&nbsp;என்ன<br />
கொடுப்பார்கள்”? எனபுள்ளிவிவர அறிக்கை விடுவார்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு வசனம் பேசுவார் -&nbsp;<strong style="margin: 0px; padding: 0px;">Information, Information is Wealth&nbsp;</strong>என்பார்.அது<br />
யாரோ எழுதிக்கொடுத்த வசனம் அல்ல. எழுத்தாளர் சுஜாதா<br />
பாய்ஸ்படத்துக்காக<br />
எழுதிக்கொடுத்த வசனம்தான். இது ஒரு நகைச்சுவை உதாரணம்.<br />
<br style="margin: 0px; padding: 0px;" />
கீழே ஒரு எளிய Table வடிவம் ஒன்றைத் தருகிறேன்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒவ்வொரு வகுப்பறைக்கும், ஒரு வருகைப்பதிவேடு வைத்திருப்பார்கள்.<br />
அதில் மாணவர் பெயர், தேதி போன்றவை இருக்கும். அதில் தினமும்<br />
மாணவர் வந்திருக்கிறாரா? இல்லையா எனக் குறித்துக்கொள்வார்கள்.<br />
<br style="margin: 0px; padding: 0px;" />
மாத இறுதியில் ஒரு குறிப்பிட்ட மாணவர் எத்தனை நாட்கள் வந்திருந்தார்?<br />
&nbsp;அல்லது எத்தனை நாட்கள் வரவில்லை எனக் கணக்கிட்டுக்கொள்ளலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
இதில் மாணவர் பெயர், தேதி முதலியவற்றை Field அல்லது Column எனலாம்.<br />
மாணவரின் பெயர் எழுத்து வடிவில் இருக்கும்.<br />
அதனை String / Character / Variable character என்போம்.<br />
<br style="margin: 0px; padding: 0px;" />
தேதி என்பது month-date-year அல்லது date/month/year போன்ற ஒரு வடிவில்<br />
அமைந்திருக்கும். இது இரண்டாவது Field ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
மாணவர் பெயர் ---&gt; character(50)<br />
தேதி ---&gt; datetime<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு மாணவருக்காக எவ்வளவு எழுத்துகளை அதிகபட்சமாக ஒதுக்குகிறோம்<br />
&nbsp;என்பதே அடைப்புக்குறிக்குள் தரப்படுகிறது.<br />
<br style="margin: 0px; padding: 0px;" />
உதாரணமாக மாணவரின் பெயர் ‘Babu’ எனக் கொண்டால் அவருடைய<br />
&nbsp;பெயரின் எழுத்துக்களின் எண்ணிக்கை 4.<br />
’valpaiyan @ Arun The Hero’ எனக் கொண்டால் அவருடைய பெயரின்<br />
ஒட்டுமொத்த எழுத்துக்களின் எண்ணிக்கை 25.<br />
<br style="margin: 0px; padding: 0px;" />
இப்படிஒவ்வொருவரின்<br />
பெயரில் உள்ள எழுத்துக்களின் எண்ணிக்கை வித்தியாசப்படுகிறது.ஆகவே<br />
&nbsp;நாமாகவே<br />
ஒரு உச்சமதிப்பு ஒன்றை கொடுத்துவிடவேண்டும். இங்கேcharacter(50) எனக்<br />
கொடுத்தால் Name என்கிற Field / Column ல் அதிகபட்சமாக50 எழுத்துக்களைப்<br />
பதிவுசெய்ய இயலும் எனக் கொள்க.<br />
<br style="margin: 0px; padding: 0px;" />
<br style="margin: 0px; padding: 0px;" />
மாணவர் பெயர் ---&gt; character(50)<br />
தேதி ---&gt; datetime இவை இரண்டும் இரண்டு Column எனக் கொண்டால்,<br />
&nbsp;இவற்றினை ஒட்டுமொத்தமாக ஒரு Table எனலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு Table என்பது பல Field களின் தொகுப்பு.<br />
<br style="margin: 0px; padding: 0px;" />
ஒரு Field என்பது குறிப்பிட்ட ஒரே மாதிரியான தகவலின் தொகுப்பு.<br />
<br style="margin: 0px; padding: 0px;" />
ஒவ்வொருFieldலும்<br />
நாம் பதிவு செய்யப்போகிற தகவலின் அடிப்படையில், எந்த<br />
மாதிரியானதகவலைப்<br />
பதிவு செய்யப் போகிறோம் என்பதை அதன் Data Type மூலம்நிர்ணயிக்கலாம்.<br />
<br style="margin: 0px; padding: 0px;" />
மாணவரின்<br />
பெயரை character(50) என்றோம். இங்கே 50என்பது எத்தனை எழுத்துக்கள்<br />
என்பதைக் குறிக்கிறது. character என்பது ஒருData Type ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
தேதி --&gt; datetime இங்கு datetime என்பது மற்றொரு வகை Data Type ஆகும்.<br />
<br style="margin: 0px; padding: 0px;" />
எழுத்துக்களைப்பதியும்போது<br />
character, எண்களைப்பதியும்போது numbers(int,bigint,decimal,float).<br />
தேதியைக் குறிக்கும்போது datetime என ஒவ்வொருவகையான<br />
&nbsp;தகவலுக்கும் ஒவ்வொரு<br />
DataType உள்ளது.<br />
<br style="margin: 0px; padding: 0px;" />
ஆகவே Data Type என்பது தகவலின் வகையைக் குறிப்பதாகும்.<br />
<br style="margin: 0px; padding: 0px;" />
SQL வாயிலாக ஒரு Table ஐ உருவாக்க / மாற்ற / அழிக்க / தகவலைத்<br />
தேட இயலும்.<br />
<br style="margin: 0px; padding: 0px;" />
Tableஎன்பதில்<br />
பல Columns இருக்கும். ஒவ்வொரு Columnன் தகவலின் வகையை<br />
&nbsp;DataTypeமூலம்<br />
நிர்ணயிக்கலாம். எவ்வளவு எழுத்துகள் என்பதை அடைப்புக்குறிக்குள்<br />
சொல்கிறோம்.<br />
<br style="margin: 0px; padding: 0px;" />
உங்கள் கணினியில் SQL கட்டளைகளை இயக்கிப் பார்ப்பதற்காக<br />
<a href="http://www.microsoft.com/downloads/details.aspx?FamilyID=220549b5-0b07-4448-8848-dcc397514b41&amp;DisplayLang=en" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank">Microsoft SQL Server 2005 Express Edition</a>&nbsp;மென்பொருளை இலவசமாகத்<br />
தரவிறக்கி உங்கள் கணினியில் நிறுவிக்கொள்ளவும்.<br />
<br style="margin: 0px; padding: 0px;" />
<strong style="margin: 0px; padding: 0px;">பின் குறிப்பு :</strong>&nbsp;வாரத்திற்கு 2 முறையாவது இந்த எளிய தமிழில் SQL என்கிற<br />
தொடர் பதிவுகளை அளிக்கலாம் என முன்வந்துள்ளேன். உங்கள் ஆதரவு<br />
தேவை.<br />
<br style="margin: 0px; padding: 0px;" />
பலபதிவுகளை<br />
பிற ஆங்கில வலைப்பூக்களில் இருந்து மொழிபெயர்த்துப்போட்டிருக்கிறேன்.<br />
அதற்கு ஆதரவளித்த அன்புள்ளங்களுக்கு நன்றி. அதுபோலஇந்தத்<br />
தொடரின் வெற்றி<br />
உங்கள் கையில்தான் உள்ளது.<br />
<br style="margin: 0px; padding: 0px;" />
முதலில் சிலterms உங்களுக்குக்<br />
குழப்பமாக இருப்பினும் தொடர்ந்து படியுங்கள். இங்கேகுறிப்பிடும்<br />
உதாரணங்களை கணினியில் செய்து பாருங்கள். வித்தியாசத்தைநீங்களே<br />
&nbsp;உணர்வீர்கள்.<br />
<br style="margin: 0px; padding: 0px;" />
இங்கே<br />
இனிவரும் காலங்களில் நான்கொடுக்கப்போகும் உதாரணங்களை<br />
இயக்கிப் பார்க்க<br />
இந்த இலவச மென்பொருளை உங்கள்கணினியில் நிறுவிக்கொள்ளவும்.<br />
<br style="margin: 0px; padding: 0px;" />
<a href="http://www.microsoft.com/downloads/details.aspx?FamilyID=220549b5-0b07-4448-8848-dcc397514b41&amp;DisplayLang=en" rel="nofollow" style="-webkit-transition: 1s; color: #105289; margin: 0px; padding: 0px; text-decoration: none; transition: 1s;" target="_blank">http://www.microsoft.com/downloads/details.aspx?FamilyID=220549b5-0b07-4448-8848-dcc397514b41&amp;DisplayLang=en</a><br />
<div style="font-size: 1.3em;">
<br /></div>
</div>
</div>
</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/7368087358026314769/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-1.html#comment-form' title='1 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7368087358026314769'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7368087358026314769'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/sql-1.html' title='எளிய தமிழில் SQL - பாகம் 1'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>1</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-6999456342896515355</id><published>2013-08-07T20:56:00.007-07:00</published><updated>2013-08-07T20:56:58.223-07:00</updated><title type='text'>Pass by value vs Pass by reference</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="color: #d52a33; font-family: Georgia, Utopia, 'Palatino Linotype', Palatino, serif; font-size: 22px; font-weight: normal; margin: 0px; position: relative;">
<br /></h3>
<div class="post-body entry-content" id="post-body-3435056033110617074" itemprop="articleBody" style="line-height: 1.4; position: relative; width: 606px;">
<div dir="ltr" trbidi="on">
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;">முந்தைய பாகத்தில்&nbsp;Named and Optional Arguments என்றால் என்னவென்று பார்த்தோம் அல்லவா? ஒரு procedure ரையோ அல்லது function னையோ call செய்யும்போது இரண்டு வழிகளில்&nbsp;</span><span style="font-family: 'Courier New', Courier, monospace;">அவற்றிற்கு&nbsp;நாம் arguments களை&nbsp;அனுப்பலாம். அவை Pass by value மற்றும் Pass by reference எனப்படும். அதைப்பற்றி&nbsp;</span><span style="font-family: 'Courier New', Courier, monospace;">இந்த பாடத்தில்&nbsp;பார்ப்போம்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">குறுக்கெழுத்துப்போட்டி அச்சிடப்பட்ட தாளை வைத்துக்கொண்டு உங்கள் வீட்டு திண்ணையில் உட்கார்ந்து கொண்டிருக்கிறீர்கள். பதில்களை நிரப்ப ஆயத்தமாகும்போது எதிர்வீட்டு நண்பர் வருகிறார். ஆசையா இருக்குப்பா! நானும் பதில் எழுதறேனே, எனக்கும் கொஞ்சம் கொடேன் என்று கேட்கிறார்.</span><br /><a href="" name="more"></a><br /><div class="separator" style="clear: both; text-align: center;">
<span style="font-family: 'Courier New', Courier, monospace;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEieOM5ltObSDe4T6jFtSvL2HgjqtO7IDkpgB7rJ2G7Nifo7wQRqA9lHPbEZJRi_SS49WWICOT02mcq4xSZNbhyY3hOsu3COn5t5HMG_SuNadxvMfoIkK_YIQKqTMle4o_EECXp9RoQuggWi/s1600/pass+by+value+vs+pass+by+reference.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="pass by value vs pass by reference, passing by value vs passing by reference, தமிழ் கம்ப்யூட்டர், தமிழ் பாடம், கல்வி" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEieOM5ltObSDe4T6jFtSvL2HgjqtO7IDkpgB7rJ2G7Nifo7wQRqA9lHPbEZJRi_SS49WWICOT02mcq4xSZNbhyY3hOsu3COn5t5HMG_SuNadxvMfoIkK_YIQKqTMle4o_EECXp9RoQuggWi/s320/pass+by+value+vs+pass+by+reference.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="320" /></a></span></div>
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">நீங்கள் அந்த தாளை அவரிடம் கொடுக்கிறீர்கள். அவர் விடைகளை எழுதுகிறார். பின்னர் அந்த தாளை உங்களிடம் தந்துவி்ட்டார்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">இப்பொழுது சொல்லுங்கள். உங்கள் கையில் இருக்கும் தாளில் உங்கள் நண்பருடைய பதில்கள் இருக்குமா? இருக்காதா?</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><span style="color: blue;">இருக்கும்.</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">சரியான பதில். எதனால் இருக்கிறது?</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><span style="color: blue;">ஏன்னா, நான் என்னுடைய தாளையல்லவா கொடுத்தேன். அதில் அவர் மாற்றம் செய்தால் அது இருக்கத்தானே செய்யும்!&nbsp;</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">மிகச் சரியாக சொன்னீர்கள்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">சரி அடுத்த கேள்வி.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">ஒருவேளை நீங்கள் அந்த தாளை ஒரு நகலெடுத்து அவரிடம் கொடுக்கிறீர்கள் என்று வைத்துக்கொள்வோம். அதில் அவர் விடைகளை எழுதுகிறார்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">உங்களிடம் உள்ள தாளில் அவருடைய பதில் இருக்குமா?</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><span style="color: blue;">இருக்காது.</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">ஏன் உங்களுடைய தாளில் அவருடைய பதில் இல்லை?</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><span style="color: blue;">ஏன்னா, நான் காப்பியைத்தானே கொடுத்தேன். ஒரிஜினல் என்கிட்டதானே இருக்கு. அவர் அந்த தாளில் மாற்றினால் அது எப்படி இந்ததாளில் இருக்கும்.</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">மிகச் சரியாக சொன்னீர்கள்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">மேற்கண்ட இரண்டு வழிகளில் எந்த வழியை எப்பொழுது தேர்ந்தெடுப்பீர்கள்?</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><span style="color: blue;">நாங்கள் இரண்டு பேரும் சேர்ந்து குறுக்கெழுத்துபோட்டிக்கு பதில் எழுதனும்னு தோன்றினால் ஒரு தாளையே பகிர்ந்துகொள்வேன்.</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="color: blue;"><br /></span></span><span style="font-family: 'Courier New', Courier, monospace;"><span style="color: blue;">அல்லது நண்பர் எழுதிய பதில் எனக்குத் தேவையில்லை என்று தோன்றினால் ஒரு நகலெடுத்து கொடுத்துடுவேன்.</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">மிகச்சரியாக சொன்னீர்கள்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">இதை நம் பாடத்தோடு பொருத்தி பார்த்தால் இப்படி உருவகப்படுத்தலாம்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">Main Program - நீங்கள்&nbsp;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">Sub Program / Procedure / Function - உங்கள் நண்பர்</span></div>
<span style="background-color: #fefdfa; color: #333333; font-family: 'Courier New', Courier, monospace; font-size: 13px; line-height: 18px;">Parameter / Formal Parameter - உங்கள் நண்பர் எதிர்பார்ப்பது</span><br style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px;" /><div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;">Argument / Actual parameter - நீங்கள் கொடுக்கும் குறுக்கெழுத்து தாள்</span></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;">Passing method - குறுக்கெழுத்து தாளை அவருக்கு கொடுக்கும் முறை</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">நீங்கள் தேர்ந்தெடுத்த வழிகளை இப்படி உருவகப்படுத்தலாம்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">நீங்கள் உங்கள் நண்பருக்கு உங்கள் தாளையே பகிர்ந்து கொடுக்கிறீர்கள்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;">Main Program sends a&nbsp;<span style="color: blue;">reference of a variable</span>&nbsp;to Sub Program</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">நீங்கள் உங்கள் உண்பருக்கு உங்கள் தாளை நகலெடுத்து கொடுக்கிறீர்கள்.</span><br /><span style="font-family: 'Courier New', Courier, monospace;">Main Program sends a&nbsp;<span style="color: blue;">copy / value of a variable&nbsp;</span>to Sub Program</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">நீங்கள் தேர்ந்தெடுக்கும் முதல் வழிக்கு பெயர்தான் Pass by reference</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">நீங்கள் தேர்ந்தெடுக்கும் இரண்டாம் வழிக்கு பெயர்தான் Pass by value</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">இரண்டிற்கும் வித்தியாசம் புரிந்ததா? உங்களுடைய தேவைக்கு தக்கவாறு ஒரு வழியை நீங்கள் தேர்ந்தெடுத்துக்கொள்ளலாம்தானே?</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><b><span style="font-family: 'Courier New', Courier, monospace;">Formal Parameter</span></b><span style="font-family: 'Courier New', Courier, monospace;">&nbsp;</span><br /><br /><span style="font-family: 'Courier New', Courier, monospace;">Formal parameter என்பது procedure definition னில் இருப்பது. அதாவது ஒரு procedure ரையோ அல்லது ஒரு function னையோ declare செய்யும்போது இன்னன்ன parameter இதற்கு தேவை என்று குறிப்பிடுவது Formal parameter ஆகும்.</span><br /><div>
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><b>Actual parameter</b></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">Actual parameter என்பது procedure ரையோ அல்லது function னையோ call செய்யும்போது நாம் கொடுக்கும் input value வாகும்.</span></div>
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><b>Pass By Reference</b></span></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">1. Actual parameter variable லுடைய address, formal parameter ருக்கு அனுப்பப்படுகிறது. இதனால்&nbsp; Actual Parameter ரும் formal parameter ரும் ஒரே memory address ஸை பயன்படுத்துகின்றன. (<span style="color: blue;">நாங்கள் இரண்டு பேரும் சேர்ந்து குறுக்கெழுத்துபோட்டிக்கு பதில் எழுதனும்னு தோன்றினால் ஒரு தாளையே பகிர்ந்துகொள்வேன்</span><span style="color: blue;">&nbsp;என்ற பதிலை ஞாபகப்படுத்தி கொள்ளவும்.)</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">2. sub program / function அந்த formal parameter value வை மாற்றினால் அது actual parameter ரைத்தான் மாற்றுகிறது.</span><br /><span style="font-family: 'Courier New', Courier, monospace;">&nbsp;&nbsp;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">3. ஒரு function 1 value வைத்தான் return செய்யும் என்கிற விதியை மாற்றி எத்தனை value வை வேண்டுமானாலும் return செய்யவைக்கலாம். அதாவது எத்தனை pass by reference பயன்படுத்துகின்றோமோ அத்தனை value க்கள் return செய்யப்படும்.&nbsp; (<span style="color: blue;">நமது உதாரணத்தில் இருக்கும்&nbsp;</span><span style="font-size: xx-small;"><span style="font-size: x-small;"><span style="color: blue;">FnReturnTwoValues என்கிற function ஐ பார்க்க</span></span></span>)</span></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">4. ஒரு procedure எதையும் return செய்யாது என்கிற விதியை மாற்றி எத்தனை value வை வேண்டுமானாலும் return செய்யவைக்கலாம். அதாவது எத்தனை pass by reference பயன்படுத்துகின்றோமோ அத்தனை value க்கள் return செய்யப்படும். (<span style="color: blue;">நமது உதாரணத்தில் இருக்கும்&nbsp;<span style="font-size: xx-small;"><span style="font-size: x-small;">GetBigestNoProc&nbsp;</span></span></span><span style="font-size: xx-small;"><span style="font-size: x-small;"><span style="color: blue;">என்கிற&nbsp;procedureஐ பார்க்க</span></span></span></span>)</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">5. Memory address share பண்ணப்படுவதால் variable களை மட்டும் தான் actual parameter ராக அனுப்பமுடியும். Value க்களை அனுப்ப முடியாது.<b>&nbsp;</b></span></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><b>Pass By Value:</b></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">1. Actual parameter variable லுடைய value, formal parameter ருக்கு அனுப்பப்படுகிறது. இதனால்&nbsp; Actual parameter ரும் formal parameter ரும் வெவ்வேறு memory address களை பயன்படுத்துகின்றன. (<span style="color: blue;">அவன் எழுதிய பதில் எனக்குத் தேவையில்லை என்று தோன்றினால் ஒரு பிரதியெடுத்து கொடுத்துடுவேன்</span><span style="color: blue;">என்ற பதிலை ஞாபகப்படுத்தி கொள்ளவும்.)</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">2. Sub program / function அந்த formal parameter value வை மாற்றினால் actual parameter மாறாது.</span><br /><span style="font-family: 'Courier New', Courier, monospace;">&nbsp;&nbsp;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">3. Variable, value என்று எதை வேண்டுமானாலும் actual parameter ராக அனுப்பமுடியும்&nbsp;</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><br /><div class="separator" style="clear: both; text-align: center;">
<span style="font-family: 'Courier New', Courier, monospace;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhx2zhvLeKVsCgI8TH1bAXc_CLtEhv2070WbmBjHLwpk2q-tQw4Q71mOWXAEWDy6C7NbRy5FpCynnZUurWjME-OrzuDuQ4ZOxUIFljInnJp0VRvBeRgVXS8LCF72Lj8CD3hmobCIA9-3M1p/s1600/how+pass+by+value+and+pass+by+reference+works.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="passing by value and passing by reference, faridh, tamil computer tips, tamil programming, கலை, கணிணி, மென்பொருள், சாப்ட்வேர், கற்கண்டு, karkandu" border="0" height="236" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhx2zhvLeKVsCgI8TH1bAXc_CLtEhv2070WbmBjHLwpk2q-tQw4Q71mOWXAEWDy6C7NbRy5FpCynnZUurWjME-OrzuDuQ4ZOxUIFljInnJp0VRvBeRgVXS8LCF72Lj8CD3hmobCIA9-3M1p/s400/how+pass+by+value+and+pass+by+reference+works.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="400" /></a></span></div>
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">உதாரணத்திற்கு அடுத்து வரும் புரோகிராமை பார்க்கவும்</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;"><span style="font-size: x-small;">procedure Main;<br />var<br />&nbsp; Val1, Val2 : Integer;<br />&nbsp; Val3, Val4 : Integer;<br />begin<br />&nbsp; Val1 := 10;<br />&nbsp; Val2 := 20;<br />&nbsp; Val3 := 0;<br />&nbsp; Val4 := Val3;<br /><br />&nbsp; //call function to get biggest among 2 numbers<br />&nbsp; Val3 := GetBigestNoFn ( Val1, Val2 );<br />&nbsp; Print Val1, Val2, Val3, Val4;<br /><br />&nbsp; //call procedure to get biggest among 2 numbers!</span></span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;">&nbsp; //pass by reference&nbsp;<span style="font-size: xx-small;">மூலம் இங்கே</span>&nbsp;procedure&nbsp;</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;">&nbsp;&nbsp;//ஒரு value வை return&nbsp;<span style="font-size: xx-small;">செய்வது போன்ற தோற்றத்தை ஏற்படுத்த முடிகிறது.&nbsp;</span></span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;"><span style="font-size: x-small;">&nbsp;</span></span><span style="font-size: x-small;">&nbsp;</span>GetBigestNoProc ( Val1, Val2,&nbsp;<span style="color: blue;">Val3&nbsp;</span>);</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;"><span style="font-size: x-small;">&nbsp; Print Val1, Val2, Val3, Val4;<br /><br />&nbsp; //One function return more than one value!</span></span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;">&nbsp; //pass by reference மூலம் இங்கே function</span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;">&nbsp;&nbsp;//more&nbsp;than&nbsp;1&nbsp;value வை return&nbsp;<span style="font-size: xx-small;">செய்வது போன்ற தோற்றத்தை ஏற்படுத்த முடிகிறது.&nbsp;</span></span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;"><span style="font-size: x-small;">&nbsp; Val4 := FnReturnTwoValues (&nbsp;<span style="color: blue;">Val1&nbsp;</span>)<br />&nbsp; Print Val1, Val2, Val3, Val4;<br />end;<br /><br />function GetBigestNoFn ( ByVal1, ByVal2 : Integer ) : Integer;<br />begin<br />&nbsp; If ByVal1 &gt; ByVal2<br />&nbsp; then Result := ByVal1<br />&nbsp; else Result := ByVal2;<br />end;<br /><br />procedure GetBigestNoProc ( ByVal1, ByVal2 : Integer;&nbsp;<span style="color: blue;">Var ByRefBigNum : Integer</span>&nbsp;);<br />begin<br />&nbsp; //pass by reference value is modified<br />&nbsp; If ByVal1 &gt; ByVal2<br />&nbsp; then ByRefBigNum := ByVal1<br />&nbsp; else ByRefBigNum := ByVal2;<br />&nbsp;<br />&nbsp; //pass by values are modified</span></span></span><br /><span style="font-family: 'Courier New', Courier, monospace;"><span style="font-size: xx-small;"><span style="font-size: x-small;">&nbsp;&nbsp;//but it will not affect actual paramters</span></span></span><br /><span style="font-family: 'Courier New', Courier, monospace;">&nbsp; ByVal1 := ByVal1 + ByVal1;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">&nbsp; ByVal2 := ByVal2 + ByVal2;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">end;</span><br /><span style="font-family: 'Courier New', Courier, monospace;"><br /></span><span style="font-family: 'Courier New', Courier, monospace;">function FnReturnTwoValues (&nbsp;<span style="color: blue;">Var ByRefRetVal : Integer</span>&nbsp;) : Integer;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">begin</span><br /><span style="font-family: 'Courier New', Courier, monospace;">&nbsp; ByRefRetVal := ByRefRetVal * 2;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">&nbsp; Return := ByRefRetVal * 2;</span><br /><span style="font-family: 'Courier New', Courier, monospace;">end;</span></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;">இந்த புரோகிராம் எப்படி வேலை செய்கிறது என்பதை விளக்கும் படத்தை கீழே காண்க</span></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<span style="font-family: 'Courier New', Courier, monospace;"><br /></span></div>
<div class="separator" style="background-color: #fefdfa; clear: both; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: center;">
<span style="font-family: 'Courier New', Courier, monospace;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjiCmXdkIdNtbHfD0dsB-_RUZ1kisr30IxHyrG45zQa1CGwh2Ok_8Hp2MwqUJDlwstLUsXiFHcUluk2q-pZT0V0fn37TDDjgI2cdr0a8PZNUpEg9Yl6w-ZNqhGMMr2QMZUa0YW66ypvIRbC/s1600/pass+by+value+vs+pass+by+reference.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="calling by value, calling by reference, tamil lessons, hello world, how to write program, programming for dummies, kalkandu, கல்கண்டு" border="0" height="281" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjiCmXdkIdNtbHfD0dsB-_RUZ1kisr30IxHyrG45zQa1CGwh2Ok_8Hp2MwqUJDlwstLUsXiFHcUluk2q-pZT0V0fn37TDDjgI2cdr0a8PZNUpEg9Yl6w-ZNqhGMMr2QMZUa0YW66ypvIRbC/s400/pass+by+value+vs+pass+by+reference.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="400" /></a></span></div>
<div>
<br /></div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/6999456342896515355/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/pass-by-value-vs-pass-by-reference.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/6999456342896515355'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/6999456342896515355'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/pass-by-value-vs-pass-by-reference.html' title='Pass by value vs Pass by reference'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEieOM5ltObSDe4T6jFtSvL2HgjqtO7IDkpgB7rJ2G7Nifo7wQRqA9lHPbEZJRi_SS49WWICOT02mcq4xSZNbhyY3hOsu3COn5t5HMG_SuNadxvMfoIkK_YIQKqTMle4o_EECXp9RoQuggWi/s72-c/pass+by+value+vs+pass+by+reference.jpg" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-7407587863393098644</id><published>2013-08-07T20:56:00.003-07:00</published><updated>2013-08-07T20:56:14.414-07:00</updated><title type='text'>Named and Optional Arguments என்றால் என்ன?</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<div class="post-body entry-content" id="post-body-7475876909202832278" itemprop="articleBody" style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; position: relative; width: 606px;">
<div dir="ltr" trbidi="on">
<div style="text-align: center;">
<br /></div>
<div style="text-align: justify;">
முந்தைய பாகத்தில்&nbsp;ஒரு procedure ரை call செய்யும் போது அதில் இருக்கும் அத்தனை parameter ருக்குமான input களையும் அதே வரிசைப்படி கொடுக்கவேண்டும். இல்லையானால் error message வரும் என்பதை பார்த்தோம்.</div>
<div style="text-align: justify;">
<br /><b>Function / procedure calling அடிப்படை -&nbsp;</b><br /><br />1) declaration னில் உள்ள parameter வரிசைப்படி value க்களை அனுப்ப வேண்டும்.</div>
<div style="text-align: justify;">
2) அனைத்து parameter ருக்குமான value க்களையும் கட்டாயம் அனுப்பவேண்டும்.&nbsp;</div>
<div style="text-align: justify;">
<br /><b>இதில் உள்ள பிரச்சினைகள் -</b></div>
<div style="text-align: justify;">
<br />1) வரிசைப்படித்தான் அனுப்ப வேண்டுமா? மாற்றி அனுப்பமுடியாதா?<br />2) கட்டாயம் அனுப்பித்தான் ஆகவேண்டுமா? விதிவிலக்கு இல்லையா?</div>
<div style="text-align: justify;">
<br /><a href="" name="more"></a>சில programming language ல் இந்த 2 பிரச்சினைகளுக்கும் தீர்வு இருக்கிறது. அவை என்னவென்று இந்த பாடத்தில் பார்ப்போம்.</div>
<div style="text-align: justify;">
<br />function ArithmeticFunction (Number1 : Float; Operator : Integer; Number2 : Float) : Float;<br />begin<br />&nbsp; If Operator = 1<br />&nbsp; then Result := Number1 + Number2<br />&nbsp; else If Operator = 2<br />&nbsp; then Result := Number1 - Number2<br />&nbsp; else If Operator = 3<br />&nbsp; then Result := Number1 * Number2<br />&nbsp; else Result := Number1 / Number2;<br />end;<br /><br />மேலே ArithmeticFunction என்ற function declare செய்யப்பட்டுள்ளது. இதில் 2 float type, 1 integer type parameter கள் உள்ளன. இது function ஆக இருக்கின்றதால் ஒரு value வை return செய்கிறது. Return ஆகக்கூடிய value float data type ஆக இருக்கிறது.<br /><br />இந்த function னை பார்த்த உடன் அது என்ன செய்கிறதென்று உங்களுக்கு புரிந்தால் உங்களுக்கு புரோகிராமிங் புரிகிறது என்று அர்த்தம். புரோகிராம் இன்னும் சரளமாக எழுதத் தெரியாவிட்டாலும் குறைந்தபட்சம் என்ன எழுதப்பட்டுள்ளதென்பதாவது புரிகிறதே. புரோகிராமர் ஆவதற்கு இதுவே அடிப்படை. நமது புரோகிராமின் ஒவ்வொரு வரியும் என்ன செய்கிறதென்று நமக்கு புரியவேண்டும். ஒரு வரி புரியாவிட்டாலும் அந்த புரோகிராம் நமது கட்டுப்பாட்டில் இல்லை என்று அர்த்தம். மண்குதிரையை நம்பி ஆற்றில் இறங்கின கதைதான்.<br /><br />ஒவ்வொரு வரியும் புரிந்துவிட்டால் மனப்பாடம் செய்யாமல்&nbsp;புரோகிராம் எழுத ஆரம்பித்துவிடலாம். ஒரு புரோகிராமில் எங்கு பிழையிருக்கிறது என்பதையும் கண்டுபிடித்துவிடலாம்.<br /><br />-- புரியாதவர்களுக்காக மேற்கண்ட புரோகிராமுடைய pseudo-code இதோ:<br />&nbsp;<br />function ArithmeticFunction (Number1 : Float; Operator : Integer; Number2 : Float) : Float;<br />begin<br />&nbsp; If Operator = 1 என்றால் கூட்டச் சொல்கிறார்கள் என்று புரிந்துகொள்<br />&nbsp; then Result := இரண்டு நம்பரையும் கூட்டவும்<br />&nbsp; else If Operator = 2 என்றால் கழிக்கச் சொல்கிறார்கள் என்று புரிந்துகொள்<br />&nbsp; then Result := முதல் நம்பரிலிருந்து இரண்டாவதை கழி<br />&nbsp; else If Operator = 3 என்றால் பெருக்கச் சொல்கிறார்கள் என்று புரிந்துகொள்<br />&nbsp; then Result := இரண்டு நம்பரையும் பெருக்கவும்<br />&nbsp; else 1,2,3 தவிர வேறெதுவும் இருந்தால்<br />&nbsp; Result := முதல் நம்பரை இரண்டாவதைக் கொண்டு வகுக்கவும்.<br />end;<br /><br />மேற்கண்ட function னானது கொடுக்கப்பட்ட parameter ருக்கு தக்கவாறு 4 விதமான செயல்களை செய்து result ஐ திருப்பிதரும் வகையில் வடிவமைக்கப்பட்டுள்ளது.<br /><br />இந்த function னை call செய்யவேண்டுமென்றால் 3 value க்களை கட்டாயம் நாம் அனுப்பவேண்டும். அதில் உள்ள வரிசைப்படி அனுப்ப வேண்டும். இதில் ஏதாவது ஒன்றை செய்யாவிட்டாலும் error என்று வரும்.<br /><br />அடுத்து Main program மிலிருந்து நமது function னை call செய்து test செய்து பார்ப்போம்.<br /><br />procedure Main;<br />Var<br />&nbsp; FirstNumber, SecondNumber, Answer : Float;<br />begin<br />&nbsp; FirstNumber := 10.10;<br />&nbsp; SecondNumber := 20.20;<br /><br />&nbsp; Answer := ArithmeticFunction (FirstNumber, 1, SecondNumber) ; //addition operation. Answer is 30.3<br />&nbsp; ShowMessage( Answer) ;<br /><br />&nbsp; Answer := ArithmeticFunction (10.10, 2, 5) ; //subtract operation. Answer is 5.1<br />&nbsp; ShowMessage( Answer) ;<br /><br />&nbsp; Answer := ArithmeticFunction (FirstNumber, 3, 5.5) ; //multiplicative operation. Answer is 55.55<br />&nbsp; ShowMessage( Answer) ;<br /><br />&nbsp; Answer := ArithmeticFunction (FirstNumber, 4, 5) ; //division operation. Answer is 2.02<br />&nbsp; ShowMessage( Answer) ;<br /><br /><span style="color: red;">&nbsp; //next line has&nbsp;</span><span style="color: red;">data type mismatch problem. Incorrect order of values;&nbsp;</span><br /><span style="color: red;">&nbsp; //second parameter is declared as integer; but float value is passed here;</span><br /><br /><span style="color: red;">&nbsp; Answer := ArithmeticFunction (FirstNumber, SecondNumber, 1) ;&nbsp;</span><br /><span style="color: red;"><span style="color: black;">&nbsp; ShowMessage( Answer) ;</span></span><br />end;<br /><br />இதில் உள்ள பிரச்சினை என்னவென்றால் formal parameter signature ரும் actual parameter signature ரும் வேறுவேறாக இருக்கின்றன. சரியான வரிசையில் value க்களை ஒழுங்கு படுத்தி திருத்தினால் புரோகிராம் வேலை செய்யும். அல்லது நாம் கொடுக்கும் value வை எந்த parameter ருக்குரியது என்று சொல்லவேண்டும். சொல்லிவிட்டால் புரோகிராம் அதை புரிந்து கொள்ளும். Error காட்டாது.<br /><br /><div>
<span style="color: blue;">குறிப்பு : Parameter களுக்கான input value க்களை arguments என்றும் குறிப்பிடுவார்கள்.</span></div>
<br /><b>Named Arguments என்றால் என்ன?</b><br /><br />எந்த value எந்த parameter ருக்குரியது என்று குறிப்பிடுவதை Named Arguments என்பர்.<br /><br />மேலே உள்ள Main Procedure ரில் சிவப்பு வண்ணத்தில் இருக்கும் வரியை இந்த வசதியை கொண்டு திருத்துவோம்.<br /><br /><span style="color: red;">பிழையான வரி</span></div>
<div style="text-align: justify;">
<span style="color: red;">Answer := ArithmeticFunction (FirstNumber, SecondNumber, 1) ;&nbsp;</span><span style="color: red;"></span><br /><span style="color: red;"><span style="color: black;"></span></span><br /><br /><span style="color: #274e13;">சரியான வழி 1: சரியான வரிசையில் மாற்றி எழுதுவது&nbsp;</span><br /><span style="color: #274e13;">Answer := ArithmeticFunction (FirstNumber, 1, SecondNumber,) ;&nbsp;&nbsp;</span><br />//கூட்டவேண்டும் என மாறிவிட்டது<br /><span style="color: #274e13;"><br /></span><span style="color: #274e13;">சரியான வழி 2: Named Arguments வசதியை பயன்படுத்துவது&nbsp;</span><br /><span style="color: #274e13;">Answer := ArithmeticFunction (Number1 = FirstNumber, Number2 = SecondNumber, Operator = 1) ;&nbsp;</span><br /><br />அதாவது எந்த value எந்த parameter ருக்குரியது என்பதை சொல்லிவிட்டதால் parameter வரிசையை பற்றி கவலைப்படத் தேவையில்லை. கூட்டவேண்டும் என புரிந்துகொள்ளும்.<br /></div>
<div style="text-align: justify;">
<b>Optional Parameters என்றால் என்ன?</b><br /><br />நமது function னில் உள்ள parameter களில் சிலவற்றிற்கு input அவசியமில்லை. வந்தால் நலம் வராவிட்டாலும் பரவாயில்லை என்ற நிலை ஏற்பட்டால் Optional Parameter என்கிற concept நமக்கு உதவியாக இருக்கிறது.<br /><br />இந்த பாடத்தின் ஆரம்பத்தில் உள்ள function னை மாற்றம் செய்து பார்ப்போம்.<br /><br />function ArithmeticFunction (Number1 : Float; Operator : Integer;&nbsp;<span style="color: blue;">Optional Number2 : Float = 1.0</span>) : Float;<br />begin<br />&nbsp; If Operator = 1<br />&nbsp; then Result := Number1 + Number2<br />&nbsp; else If Operator = 2<br />&nbsp; then Result := Number1 - Number2<br />&nbsp; else If Operator = 3<br />&nbsp; then Result := Number1 * Number2<br />&nbsp; else Result := Number1 / Number2;<br />end;<br /><br />இந்த function னை call செய்யவேண்டுமென்றால் இரண்டு parameter ருக்கான value க்களை கட்டாயம் நாம் அனுப்பவேண்டும். ஒரு parameter ருக்கான value வை அனுப்பவேண்டிய கட்டாயமில்லை. அனுப்பினால் அது எடுத்துக்கொள்ளப்படும். அனுப்பாவிட்டால் அதில் உள்ள Default Value எடுத்துக்கொள்ளப்படும்.<br /><br /><span style="color: blue;">Optional Number2 : Float = 1.0 என்பதன் அர்த்தம்...</span><br /><span style="color: blue;"><br /></span><span style="color: blue;">Number2 என்பது Float data type வகையைச் சேர்ந்த ஒரு Optional Parameter ஆகும் இதன் default value 1.0 ஆகும்.</span><br /><br />இங்கே கவனிக்கவேண்டிய விசயம்:<br /><br />ஒரு function னில் உள்ள அனைத்து parameter களும்&nbsp; Optional Parameter களாக இருந்தாலும் கூட பிரச்சினை எதுவும் கிடையாது.<br /><br /><b>நிபந்தனைகள்</b><br /><br />Optional Parameter ருக்கு அடுத்து வலப்புறத்தில் எந்தவொரு கட்டாய parameter ரும் இருக்கக்கூடாது.<br /><br />Optional Parameter கள் அனைத்தும் function னில் வலதுபுறத்தில்தான் declare செய்யப்படவேண்டும்.<br /><br />Optional Parameter ருக்கு default value ஒன்று கண்டிப்பாக இருக்கவேண்டும்.<br /><br /><b>பிரச்சினைகளும் தீர்வுகளும்&nbsp;</b><br /><br />ஒரு procedure ரை call செய்யும் போது அதில் இருக்கும் அத்தனை parameter ருக்குமான input களையும் அதே வரிசைப்படி கொடுக்கவேண்டும் என்பதில் உள்ள பிரச்சினைகளும் அதற்கான தீர்வுகளும்.<br /><br />1) வரிசைப்படிதான் அனுப்ப வேண்டுமா? மாற்றி அனுப்பமுடியாதா?<br /><span style="color: blue;">வரிசை மாற்றியும் அனுப்பலாம்.&nbsp;இதற்கு Named Arguments தீர்வாக அமைந்ததை கண்டோம்.</span><br /><br />2) கட்டாயம் அனுப்பித்தான் ஆகவேண்டுமா? விதிவிலக்கு இல்லையா?</div>
<div style="text-align: justify;">
<span style="color: blue;">Value வை அனுப்பாமலும் இருக்கலாம். இதற்கு Optional Parameters தீர்வாக அமைந்ததை கண்டோம்.</span><br /><br />இறைவன் நாடினால் அடுத்த பாடத்தில்&nbsp;Pass by value, Pass by reference பற்றி பார்ப்போம்.</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/7407587863393098644/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/named-and-optional-arguments.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7407587863393098644'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/7407587863393098644'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/named-and-optional-arguments.html' title='Named and Optional Arguments என்றால் என்ன?'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-4352366461774362411</id><published>2013-08-07T20:55:00.003-07:00</published><updated>2013-08-07T20:55:34.365-07:00</updated><title type='text'>Parameters or Arguments என்றால் என்ன?</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<div class="post-body entry-content" id="post-body-8505527633362985046" itemprop="articleBody" style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; position: relative; width: 606px;">
<div dir="ltr" trbidi="on">
<div style="text-align: center;">
<br /></div>
<div style="text-align: justify;">
முந்தைய பாகத்தில்&nbsp;subroutine பற்றி பார்த்தோம் அல்லவா அதன் தொடர்ச்சியாக parameter என்றால் என்னவென்று பார்ப்போம்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<b>Parameters என்றால் என்ன?</b></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
ஒரு procedure இயங்குவதற்கு input ஆக சிலவற்றை கொடுக்க நேரிடலாம். அத்தகைய input களை parameters என்றும் arguments என்றும் குறிப்பிடுவார்கள்.</div>
<div style="text-align: justify;">
<a href="" name="more"></a><br /><b>Parameter இல்லாமல் procedure எழுதமுடியுமா?</b></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
முடியும். ஆனால் அந்த procedure&nbsp; எப்போதும் ஒரே மாதிரியாகவே செயல்படும். ஒருவேளை நமது தேவைக்கேற்ற மாதிரி அந்த procedure செயல்படவேண்டுமானால் அதற்கு parameter அவசியம்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
அதாவது நாம் என்ன செய்யசொல்கிறோம் என்பதை கவனித்து அதன்படி ஒரு Procedure செயல்படவேண்டுமென்றால் நாம் எதையாவது சொல்லவேண்டும். அந்த எதையாவதுதான் parameter ஆகும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<b>Procedure without parameter உதாரணம் :</b></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
உங்கள் வீட்டில் காபி பிளாஸ்க் இருக்கும்தானே? அதில் அம்மா காபியை ஊற்றிவைத்திருப்பார்கள். எப்பொழுது தேவையோ அப்பொழுது அதிலிருந்து காபியை எடுத்துக்கொள்ள முடியும். அதாவது எத்தனை தடவை நீங்கள் கேட்டாலும் உள்ளேயிருக்கும் ஒரேயொரு காபியைத்தவிர வேறொன்றையும் அது தராது. இது procedure or function without parameter ருக்கும் பொருந்தும்.&nbsp;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<br /></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2HGXWQBEJkw01FwayTcyBsPNI7Gc9rMPrq5n9PFaJtvKxxwmgw3a-Qa701kjGJ1ywi0Tz2u0d9CuRlGXIlddOeMtU0ugUniSGuDdzvqAxNIecLmu3xE_l4i84_F7TOOqKkKQ9MQ8tAKbC/s1600/procedure_without_parameter_example.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="function without parameter, procedure without parameter, programming guide" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2HGXWQBEJkw01FwayTcyBsPNI7Gc9rMPrq5n9PFaJtvKxxwmgw3a-Qa701kjGJ1ywi0Tz2u0d9CuRlGXIlddOeMtU0ugUniSGuDdzvqAxNIecLmu3xE_l4i84_F7TOOqKkKQ9MQ8tAKbC/s320/procedure_without_parameter_example.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="256" /></a></div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<div>
procedure CoffeeMaker;</div>
<div>
begin</div>
<div>
&nbsp; print 'My Name Is Coffee Maker';</div>
<div>
&nbsp; print 'I can make coffee only';</div>
<div>
&nbsp; print 'If you press 1000 times also, i cannot give you anything other than coffee'</div>
<div>
&nbsp; print 'If you want your favorite drink. Please use CoffeMakerWithParameter'</div>
<div>
end;</div>
<div>
<br />மேலே உதாரணத்தில் உள்ள CoffeeMaker என்கிற procedure எந்த input டையும் பெறாமல் ஒரே மாதிரியான வேலையையே செயல்படுத்தும். உங்களுடைய தேவையும் இதுதான் என்றால் இப்படி எழுதி பயன்படுத்திக் கொள்ளலாம்.</div>
<br /><b>Procedure with parameter உதாரணம் :</b></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
வெளியே எங்காவது போயிருக்கும் போது காபி மெஷின் உங்கள் கண்ணில் பட்டிருக்குமே? அதை கவனித்திருக்கிறீர்களா? அதினுள்ளே பால், தண்ணீர், சர்க்கரை, காபி தூள், டீ தூள் என்று எல்லாவற்றையும் தனித்தனியாக வைத்திருப்பார்கள். அத்துடன் உங்களது விருப்பத்தை தெரிவிக்க படங்களுடனோ அல்லது பெயர்களுடனோ கூடிய பல பொத்தான்களையும் வைத்திருப்பார்கள். எந்த பொத்தானை நீங்கள் அழுத்துகிறீர்களோ அதற்குரிய பானம் கிடைக்கும். இது procedure or function with parameter ருக்கும் பொருந்தும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
உங்கள் விருப்பத்தை தெரிவிக்க உள்ள பொத்தான்களே&nbsp; parameter ஆகும்.</div>
<div style="text-align: justify;">
<br /></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhJyBKxwXlXK5aum95SWQ8JSy55DqkedPgcXZz4e1sdBwZ1Yt-TZJGDL0aTRY4_SUrHnbK7OuWEe5RryF7W4xhauGAS9P4wigA9fGuqapGSdKrpwypGzW7cZfP83J9wX8Szdwp4jY70WZMH/s1600/procedure_with_parameter.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="function with parameters, procedure with parameter" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhJyBKxwXlXK5aum95SWQ8JSy55DqkedPgcXZz4e1sdBwZ1Yt-TZJGDL0aTRY4_SUrHnbK7OuWEe5RryF7W4xhauGAS9P4wigA9fGuqapGSdKrpwypGzW7cZfP83J9wX8Szdwp4jY70WZMH/s320/procedure_with_parameter.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="305" /></a></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
procedure CoffeMakerWithParameter (YourOption : String);</div>
<div style="text-align: justify;">
begin</div>
<div style="text-align: justify;">
&nbsp; print 'My Name Is Coffee Maker';</div>
<div style="text-align: justify;">
&nbsp; print 'I can make varieties of coffee and tea';</div>
<div style="text-align: justify;">
&nbsp; print 'You asked - ' + YourOption;</div>
<div style="text-align: justify;">
&nbsp; print 'Your drink is ready. Thank you';</div>
<div style="text-align: justify;">
end;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<div>
மேலே உதாரணத்தில் உள்ள CoffeMakerWithParameter என்கிற procedure ஒரு input டை பெற்று அதற்கு தகுந்த வேலையை செயல்படுத்தும். உங்களுடைய ஒரு procedure பல்வேறு நோக்கங்களுக்காக பயன்படவேண்டுமென்றால் இப்படி எழுதி பயன்படுத்திக் கொள்ளலாம்.<br /><br />சரி வாங்க உங்களுக்கு விருப்பமான காபி சாப்பிட்டுக்கிட்டே பாடத்தையும் படிக்கலாம். கீழே உள்ள main procedure ரிலிருந்து நாம் எழுதிய இரண்டு procedure களையும் call செய்து பார்ப்போம்.</div>
<div>
<br />procedure Main;</div>
</div>
<div style="text-align: justify;">
begin</div>
<div style="text-align: justify;">
&nbsp; --next code will call procedure without parameter</div>
<div style="text-align: justify;">
&nbsp; CoffeeMaker;</div>
<div style="text-align: justify;">
&nbsp; --again coffee only</div>
<div style="text-align: justify;">
&nbsp; CoffeeMaker;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
&nbsp; --next code will call procedure with parameter</div>
<div style="text-align: justify;">
&nbsp; CoffeeMakerWithParameter ('Coffee') ;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
&nbsp; --i can order any variety</div>
<div style="text-align: justify;">
&nbsp; CoffeeMakerWithParameter ('BlackCoffee') ;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
&nbsp; CoffeeMakerWithParameter ('CoffeeWithMilk') ;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
&nbsp; CoffeeMakerWithParameter ('CoffeeWithout Sugar') ;</div>
<div style="text-align: justify;">
<br />&nbsp;&nbsp;<span style="color: red;">-- this is wrong. Parameter is missing</span><br /><div>
<span style="color: red;">&nbsp; CoffeeMakerWithParameter () ;</span></div>
<div>
<br /></div>
</div>
<div style="text-align: justify;">
end;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<b>Formal parameter vs Actual parameter :</b></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
Formal parameter என்பது procedure definition னில் இருப்பது. அதாவது ஒரு procedure ரையோ அல்லது ஒரு function னையோ declare செய்யும்போது இன்னன்ன parameter இதற்கு தேவை என்று குறிப்பிடுவது Formal parameter ஆகும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
procedure CoffeMakerWithParameter (YourOption : String);<br /><br />இது procedure declaration ஆகும். இங்கே YourOption என்பது formal parameter ஆகும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
Actual parameter என்பது procedure ரையோ அல்லது function னையோ call செய்யும்போது நாம் கொடுக்கும் input value வாகும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
&nbsp; CoffeeMakerWithParameter ('BlackCoffee') ;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
&nbsp; CoffeeMakerWithParameter ('CoffeeWithMilk') ;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
&nbsp; CoffeeMakerWithParameter ('CoffeeWithout Sugar') ;</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
இங்கே<br />'BlackCoffee'</div>
<div style="text-align: justify;">
'CoffeeWithMilk'</div>
<div style="text-align: justify;">
'CoffeeWithout Sugar' முதலியவை actual parameter ஆகும்.</div>
<div style="text-align: justify;">
<br />ஒரு function / procedure ரில் எத்தனை parameter வேண்டுமானாலும் இருக்கலாம். என்ன! அந்த procedure ரை call செய்யும் போது அத்தனை parameter ருக்குமான input களையும் அதே வரிசைப்படி கொடுக்கவேண்டும். இல்லையானால் error message வரும் அல்லது procedure எதிர்பார்த்தபடி வேலைசெய்யாது. ஆனால் சில programming language ல் இந்த பிரச்சினைக்கும் ஒரு தீர்வு இருக்கிறது. அது என்னவென்று அடுத்து பார்ப்போம்.<br /><br /></div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/4352366461774362411/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/parameters-or-arguments.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4352366461774362411'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4352366461774362411'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/parameters-or-arguments.html' title='Parameters or Arguments என்றால் என்ன?'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2HGXWQBEJkw01FwayTcyBsPNI7Gc9rMPrq5n9PFaJtvKxxwmgw3a-Qa701kjGJ1ywi0Tz2u0d9CuRlGXIlddOeMtU0ugUniSGuDdzvqAxNIecLmu3xE_l4i84_F7TOOqKkKQ9MQ8tAKbC/s72-c/procedure_without_parameter_example.jpg" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-2590190385518829736</id><published>2013-08-07T20:54:00.002-07:00</published><updated>2013-08-07T20:54:59.581-07:00</updated><title type='text'>Procedures பற்றிய விரிவான விளக்கம்</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<div class="post-body entry-content" id="post-body-2860630491299720669" itemprop="articleBody" style="line-height: 1.4; position: relative; width: 606px;">
<div dir="ltr" trbidi="on">
<div style="text-align: center;">
<br /></div>
<div style="text-align: center;">
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
முந்தைய பாகத்தில்&nbsp;subroutine னுடைய பயன்களை அறிந்துகொண்டோம். இந்த பாகத்தில் இன்னும் விவரமாக பார்ப்போம்.<br /><br />Procedures / functions / sub-program / subroutine&nbsp; என்று எப்படி குறிப்பிட்டாலும் அதனுடைய நோக்கம் நமது புரோகிராமை சிறு சிறு துண்டுகளாக பிரிப்பது என்பதால் குழப்பமடையத் தேவையில்லை.<br /><br />இதில்&nbsp;sub-program / subroutine என்று தனியாக எதுவும் கிடையாது. ஆனால் Procedure ரையோ அல்லது function னையோ குறிப்பிட இவை பயன்படுத்தப்படுகிறது. ஆகையால்procedure மற்றும் function னை பற்றி தெரிந்துகொண்டாலே போதுமானது.<br /><br /><a href="" name="more"></a><b>Procedure என்றால் என்ன?</b><br /><br />ஒரு செயலை எப்படி செயல்படுத்துவது என்பது பற்றிய கட்டளைகளை உள்ளடக்கியதை procedure எனலாம்.<br /><br />நமது புரோகிராமில் ஒரு சில கட்டளைகளை திரும்ப திரும்ப செயல்படுத்த நேரிட்டால் அவற்றை ஒரு procedure ஆகவோ அல்லது function ஆகவோ எழுதிக்கொண்டு தேவைப்படும் இடத்தில் call செய்து கொள்ளலாம்.<br /><br />இந்த procedure ஐ நாம் call செய்தால் தனக்குள் இருக்கும் கட்டளைகளை அது செயல்படுத்தும்.<br /><br /><u><b>Procedure Syntax</b></u><br /><br /><b>procedure procedure_name</b>&nbsp;(optional parameters)<br />begin<br />-- procedure body..<br />-- mention what procedure to do<br />end;<br /><br /><u><b>Function Syntax</b></u><br /><br /><b>function function_name</b>&nbsp;(optional parameters) :&nbsp;<b>return_type</b><br />begin<br />-- body of function<br />--&nbsp;mention what function to do<br />&nbsp;&nbsp;&nbsp;<b>return</b>&nbsp;something;<br />end;<br /><br />மேற்கண்ட&nbsp;இரண்டிற்குமிடையே உள்ள வித்தியாசம் என்னவென்று தெரிகிறதா?<br /><br />ஆம் return என்பது function னில் இருக்கிறது ஆனால் procedure ரில் இல்லை.<br /><br />Procedure ரும் function னும் ஒரே மாதிரி செயல்பட்டாலும் Procedure எந்த value வையும் return செய்யாது. ஆனால் function இறுதியில் ஒரு value வை return&nbsp; செய்யும்.<br /><br /><b>Procedure இல்லாமல் program எழுத முடியுமா?</b><br /><br />முடியும். சிறிய program மாக இருந்தால் பிரச்சினை இருக்காது. ஆனால் பெரிய Program மாக இருந்தால் procedure ரை தவிர்க்கவே முடியாது.<br /><br />ஒருவர் தன்னுடைய கடைக்கு ஒரு program வேண்டுமென்று கேட்கிறார். அவருடைய கடையை நிர்வகிக்க என்னென்னவெல்லாம் தேவைப்படும் என்று யோசனை செய்ததில் cash invoice, credit invoice, purchase invoice, cash receipt, cash payment, voucher என்று பட்டியல் தெரியவந்தது.&nbsp;Sample ளுக்கு இரண்டு format டுகளை தயாரித்து அவரிடம் நம்ம programmer காண்பிக்கிறார். ஆஹா அருமை என்று பாராட்ட அவரும் புரோகிராம் எழுதுகிறார்.<br /><br />கீழே உள்ள இரு படங்களை பார்க்கவும்.<br /><br /><br /><div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgP3S-L_4tXDzeANOtAbzUL_Soym4tonPBDER-dkWzdXicuEkMqvuVuUunswRUbCmyE_4Jdq7mByIi6s3zWKiA-8RNnIEbWhX4XGp0LQltOfroHlySCEg5jbVTYEb91UF4xp0Rq_IvR87pl/s1600/cash+invoice.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="sample cash invoice, karkandu, tamil programming guide" border="0" height="303" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgP3S-L_4tXDzeANOtAbzUL_Soym4tonPBDER-dkWzdXicuEkMqvuVuUunswRUbCmyE_4Jdq7mByIi6s3zWKiA-8RNnIEbWhX4XGp0LQltOfroHlySCEg5jbVTYEb91UF4xp0Rq_IvR87pl/s320/cash+invoice.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="320" /></a></div>
<div style="text-align: center;">
Sample Cash Invoice</div>
<div style="text-align: center;">
<br /></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj2uURAQ32Imxwh51-YWqA19vFok81gVM3sMbMqvV8MlR3akQ3i9PoTQXhQhinYrRtNEakChmNd53ErViDBlQIn-6Fs1MdxZ2lViuuSlQmrGBauk9lG0506vM67qGzUaZwCjPBHFV-bNFzZ/s1600/credit+invoice.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="sample credit invoice, procedures vs functions" border="0" height="303" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj2uURAQ32Imxwh51-YWqA19vFok81gVM3sMbMqvV8MlR3akQ3i9PoTQXhQhinYrRtNEakChmNd53ErViDBlQIn-6Fs1MdxZ2lViuuSlQmrGBauk9lG0506vM67qGzUaZwCjPBHFV-bNFzZ/s320/credit+invoice.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="320" /></a></div>
<div style="text-align: center;">
Sample Credit Invoice</div>
<div>
<br /></div>
மேற்கண்ட இரண்டு format களையும் print செய்ய எப்படி code எழுதியுள்ளார் என்று பார்ப்போம்.<br /><div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgGq0Rb1RawSLn_DBlkKOMiOX99pvxZNRsCbeh9eP2lrNFzCUvQ6RbAQ7ImYKYnL39NzF0p5JQg_SZbnyrHo4Fah860pLCw3rQo0LdKKYRJhhRDQeihWrOMligXVs7xi2laI-kFD5tyVcYd/s1600/program+without+procedure.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="program without procedures, procedure example, தமிழ் கம்ப்யுட்டர்" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgGq0Rb1RawSLn_DBlkKOMiOX99pvxZNRsCbeh9eP2lrNFzCUvQ6RbAQ7ImYKYnL39NzF0p5JQg_SZbnyrHo4Fah860pLCw3rQo0LdKKYRJhhRDQeihWrOMligXVs7xi2laI-kFD5tyVcYd/s320/program+without+procedure.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="168" /></a></div>
மேலோட்டமாக பார்க்கும் போது code சரியாக இருப்பது போல தோன்றினாலும்என்னென்ன&nbsp;பிரச்சினைகள் இதிலுள்ளன என்று பார்ப்போமா?<br /><ol>
<li style="margin: 0px 0px 0.25em; padding: 0px;">இரண்டு invoice களிலும் company யினுடைய பெயரை பிரிண்ட் செய்கிறார். இதற்காக இரண்டு invoice களிலும் தனித்தனியாக code எழுதியுள்ளார்.</li>
<li style="margin: 0px 0px 0.25em; padding: 0px;">அதேபோல இரண்டு invoice களிலும் footer note print செய்ய தனித்தனியாக code எழுதியுள்ளார்.&nbsp;</li>
<li style="margin: 0px 0px 0.25em; padding: 0px;">இப்படி ஒரே மாதிரியான code ஒரு புரோகிராமில் திரும்பத்திரும்ப பயன்படுத்துவது code redundancy யை உண்டாக்கும். அதென்ன redundancy? அதாங்க duplicate code.</li>
</ol>
இப்படியாக 10 வகையான screen களை design செய்து program செய்துவிட்டபின்பு கடைக்காரருக்கு ஒரு யோசனை தோன்றுகிறது. ஏம்ப்பா தம்பி கடை டெலிபோன் நம்பர் தலைப்புல இருந்தா நல்லாயிருக்குமே அதை விட்டுட்டீங்களேன்னு ஒரே போடு போட, நம்மாளும் சரிங்கன்னு போய் மாற்றிவிடுகிறார்.&nbsp;</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br />பின்பு பார்த்தால் 10 invoice ல நான்குல போன் நம்பரை காணோம். என்னாயிற்றுன்னு guess பண்ண முடியுதா? ஆம். அதேதான்... நம்மாளு எல்லா invoice லேயும் மாற்ற மறந்துட்டார். Code redundancy இருந்தால் இந்த தவறு கண்டிப்பாக நிகழும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br />இப்படியாக ஒவ்வொரு modification செய்யும்போதும் ஏதாவதொரு தவறு எங்காவது நிகழத்தான் செய்யும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br />அப்போ இதை தவிர்க்க வழியே கிடையாதான்னு நீங்கள் நினைக்கலாம். வழி இருக்கிறது வாங்க procedure&nbsp;இதற்கு&nbsp;எப்படி பயன்படுதுன்னு பார்க்கலாம்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div class="separator" style="background-color: #fefdfa; clear: both; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgzmhL-Rg7FitPUZgDA_kQ6wkL0Z6NMwDZ1F7FJDp88QLMkwsrjcOvaPuRBdrEZWZUFcGq8liKreBzpHBFSwX_F7vkUOo5Hvq2z37M_1cdrwL5GTSt4tAcRMP9pDQ5eNMkzGr52umwpuj4H/s1600/program+with+procedure.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="program with procedure or function, procedures, functions, தமிழ் கம்ப்யூட்டர்" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgzmhL-Rg7FitPUZgDA_kQ6wkL0Z6NMwDZ1F7FJDp88QLMkwsrjcOvaPuRBdrEZWZUFcGq8liKreBzpHBFSwX_F7vkUOo5Hvq2z37M_1cdrwL5GTSt4tAcRMP9pDQ5eNMkzGr52umwpuj4H/s320/program+with+procedure.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="218" /></a></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இங்கே இரண்டு procedure கள்&nbsp; எழுதப்பட்டுள்ளன. இரண்டையும் எத்தனை தடவை வேண்டுமானாலும் call செய்துகொள்ளலாம். ஒரு Procedure எப்படி வேலை செய்கிறதென்பதும் அம்புக்குறி மூலம் விளக்கப்பட்டுள்ளது.<b>&nbsp;</b><br /><br /><b>Void function&nbsp;</b><br /><br />C, C++ முதலிய&nbsp;Programming Language களில் Procedure&nbsp; என்று தனியாக எதுவும் இருக்காது. Function மட்டும் தான் இருக்கும். இருப்பினும் அதை Procedure போல வேலை செய்ய வைக்கலாம். எப்படி என்கிறீர்களா? Void Function என்று எழுதிக்கொள்ளலாம். Void என்றால் Function which does not return anything என்று அர்த்தம். அதாங்க Procedure.<br /><br />Void Function = Procedure&nbsp; (இரண்டும் சமம்)</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /><b><span style="font-weight: normal;"><b>இதனால் கிடைக்கும் பயன்கள்</b>:</span></b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<ol>
<li style="margin: 0px 0px 0.25em; padding: 0px;"><b>Code reusability</b>&nbsp;- ஒரே code ஐ பல இடங்களில் பயன்படுத்திக்கொள்ள முடிகிறது.<b>&nbsp;</b></li>
<li style="margin: 0px 0px 0.25em; padding: 0px;"><b>Avoid redundancy</b>&nbsp;- ஒரே code ஐ பல தடவை duplicate ஆக திரும்பத்திரும்ப எழுதுவது தவிர்க்கப்படுகிறது.</li>
<li style="margin: 0px 0px 0.25em; padding: 0px;"><b>Reduce complexity</b>&nbsp;- நமது புரோகிராமை பிரித்து subroutine களாக எழுதுவதால் புரிந்து கொள்வது (பராமரிப்பது) எளிதாகிறது.&nbsp;&nbsp;</li>
</ol>
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இப்போ சொல்லுங்க, கடைக்காரர் தலைப்பிலேயோ அல்லது கீழ்ப்புறத்திலோ எங்கு மாற்றம் செய்ய விரும்பினாலும் ஒரு இடத்தில் மாற்றம் செய்தால் அது அனைத்து இடங்களிலும் பிரதிபலிக்கும்தானே?.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
என்ன புரிந்ததா ?<br /><br />நல்லது...இனி</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<ul style="line-height: 1.4; list-style-image: initial; list-style-position: initial; margin: 0.5em 0px; padding: 0px 2.5em;">
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">Procedure with parameters</li>
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">Named parameters</li>
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">Optional parameters</li>
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">Pass by value</li>
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">Pass by reference</li>
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">Built-in function</li>
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">User defined function</li>
<li style="border: none; margin: 0px 0px 0.25em; padding: 0.25em 0px;">Variable scope</li>
</ul>
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
என்றால் என்ன என்பதை அடுத்து பார்க்கலாம்.</div>
<div>
<br /></div>
</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/2590190385518829736/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/procedures.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2590190385518829736'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2590190385518829736'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/procedures.html' title='Procedures பற்றிய விரிவான விளக்கம்'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgP3S-L_4tXDzeANOtAbzUL_Soym4tonPBDER-dkWzdXicuEkMqvuVuUunswRUbCmyE_4Jdq7mByIi6s3zWKiA-8RNnIEbWhX4XGp0LQltOfroHlySCEg5jbVTYEb91UF4xp0Rq_IvR87pl/s72-c/cash+invoice.jpg" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-2609907517347897525</id><published>2013-08-07T20:52:00.002-07:00</published><updated>2013-08-07T20:52:52.778-07:00</updated><title type='text'>Subroutine என்றால் என்ன?</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<h3 class="post-title entry-title" style="background-color: #fefdfa; color: #d52a33; font-family: Georgia, Utopia, 'Palatino Linotype', Palatino, serif; font-size: 22px; font-weight: normal; margin: 0px; position: relative;">
<br /></h3>
<div class="post-body entry-content" id="post-body-8441927210340659312" itemprop="articleBody" style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; position: relative; width: 606px;">
<div dir="ltr" trbidi="on">
<div style="text-align: center;">
<div style="text-align: justify;">
முந்தைய பாகத்தில்&nbsp;loop என்றால் என்னவென்று பார்த்தோம். இனி subroutine என்றால் என்ன? அது எதற்காக பயன்படுகிறது என்பதை பார்ப்போம்.</div>
</div>
<div style="text-align: justify;">
<div>
<br /></div>
<div>
<b>Subroutine என்றால் என்ன?</b></div>
<div>
<br />நாம் எழுதும் புரோகிராமை நமது வசதிக்கேற்ப அல்லது பயன்பாட்டிற்கேற்ப சிறிய சிறிய அளவில் தனித்தயாக - துண்டுகளாக - எழுதுவதை subroutine என்கிறோம்.&nbsp;&nbsp;</div>
<div>
<br /><a href="" name="more"></a>இதனால் நமது புரோகிராம் பல சின்ன புரோகிராம்களாக பிரிக்கப்படுகிறது. இதனால் இவற்றை பராமரிப்பதும் எளிதாகிவிடுகிறது.</div>
<div>
<br /></div>
</div>
<div style="text-align: justify;">
ஒரு காரியத்திற்காக program ஒன்றை எழுதுகிறோம். அதே காரியம் இன்னொரு இடத்திலும் செய்யவேண்டிய தேவை எழுகிறது. இதற்காக மீண்டும் அதே program மை உட்கார்ந்து எழுதாமல் முன்னர் எழுதிய &nbsp; அதே புரோகிராமை நாம் பயன்படுத்திகொள்ளலாம்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br /><b><b>Subroutine&nbsp;</b>னால் கிடைக்கும் பயன்கள்:&nbsp;</b></div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br /><b>Code reusability</b>&nbsp;- ஒரே code ஐ பல இடங்களில் பயன்படுத்திக்கொள்ள முடிகிறது.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br /><b>Avoid redundancy</b>&nbsp;- ஒரே code ஐ பல தடவை duplicate ஆக திரும்பத்திரும்ப எழுதுவது தவிர்க்கப்படுகிறது.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br /><b>Reduce complexity</b>&nbsp;- நமது புரோகிராமை பிரித்து subroutine களாக எழுதுவதால் புரிந்து கொள்வது (பராமரிப்பது) எளிதாகிறது.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
நடைமுறை உதாரணம் ஒன்று சொன்னால் எளிதாக விளங்கும். தென்னை மரமேறி தேங்காய் பறிப்பதற்கு ஒருத்தர் ஒரு கருவி செய்து வைத்திருக்கிறார். அவருடைய கொல்லையில் அந்த கருவியை பயன்படுத்தி தேங்காய் பறித்து கொள்கிறார். இதை அந்த ஊர் மக்கள் கேள்விபட்டு தங்கள் கொல்லையிலும் தேங்காய் பறிக்க அவரைக் கூப்பிடுகிறார்கள். அவரும் ஒருவருடைய கொல்லைக்கு போய் உட்கார்ந்து தென்னை மரமேறுவதற்கென ஒரு கருவி செய்தாகனும் என முடிவுசெய்கிறார். கருவியை தயாரிக்க தொடங்கி பல முறை முயற்சிசெய்து சில முறை கீழேயும் விழுந்து அதிலிருந்து பாடம் கற்று ஒருவழியாக அந்த கருவியை தயாரித்து தேங்காய் பறிப்பதற்குள் போதும்போதும் என்றாகிவிட்டது.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />இதை கேள்விபடும் உங்களுக்கு என்ன தோன்றுகிறது? அடப்பாவி வீட்டுல சூப்பரா ஒரு கருவியை வச்சிக்கிட்டு அதை பயன்படுத்தாம இப்படியே வீட்டுக்கு வீடு போய் கருவி செய்துகிட்டு இருக்கானே! இவனுக்கு என்ன கிறுக்கா புடிச்சிருக்கு என்று நினைப்பீர்களா இல்லையா?</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />இவருக்கு கருவி செய்ய தெரியும் என்றாலும் அதனால் ஏற்படும் விளைவுகள் என்னென்ன?</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />முதன்முதலில் ஒரு கருவியை செய்யும்போது ஏற்பட்ட காலவிரயம் ஒவ்வொருதடவையும் ஏற்படுகிறது.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />ஒவ்வொரு முறை புதிது புதிதாக செய்வதால் ஒவ்வொரு கருவியிலும் ஏதாவதொரு technical fault ஏற்பட சாத்தியம் உள்ளது.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />இப்படியே பல கருவிகள் அவன் வீட்டில் சேர ஆரம்பித்தால் நாளை எந்த கருவி நன்றாக வேலை செய்கிறது என்பது தெரியாமல் போய்விட வாய்ப்புண்டு.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />ஒரு கருவியில் ஏற்பட்ட technical fault ஐ சரிசெய்தாலும் அதே fault ஐ அனைத்து கருவிகளிலிருந்தும் நீக்க முடியும் என்பதற்கு உத்தரவாதம் கிடையாது.&nbsp;</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />இப்படி ஏகப்பட்ட பிரச்சினைகள் இதில் உள்ளன.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />இவன் சரிப்பட்டு வரமாட்டான் என்று பக்கத்து ஊரிலிருந்து ஒருத்தனை அழைத்து வந்தார்கள். அவன் தன்னுடன் கருவியையும் எடுத்துவந்திருந்தான். அந்த கருவியை பயன்படுத்தி மரமேறி தேங்காய் பறித்தான். ஒவ்வொரு முறையும் ஏதாவதொரு technical fault ஏற்பட்டால் அதை களைவது எப்படி என யோசனை செய்து குறைகளை களைந்து அந்த கருவியை மிகச்சிறந்ததாக மாற்றிவிட்டான். இதனால் இவனுக்கு நேரம் மிச்சமாகியது. வருமானமும் அதிகமானது.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />ஓய்வு நேரத்தில் அவன் வெவ்வேறு வேலைக்கு தேவைப்படும் இயந்திரங்களை கண்டுபிடிக்க ஆரம்பித்தான்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
இரண்டு நபருக்கும் உள்ள வேறுபாடு தெரிகிறதா?</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />தெரிந்தால்தான் உங்களுக்கு code reusability, avoid redundancy, reduce complexity யின் அர்த்தம் புரியும். Subroutine னுடைய தேவையும் புரியும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br />இதனை procedures / functions / sub-program / subroutine&nbsp; என்றும் குறிப்பிடுவார்கள். அதைப் பற்றி அடுத்த பாகத்தில் பார்ப்போம்.</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/2609907517347897525/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/subroutine.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2609907517347897525'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/2609907517347897525'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/subroutine.html' title='Subroutine என்றால் என்ன?'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-4235513249994285043</id><published>2013-08-07T05:28:00.004-07:00</published><updated>2013-08-07T05:28:53.781-07:00</updated><title type='text'>While Loop பில் பல ரகம்</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<div class="post-body entry-content" id="post-body-7638801517875399553" itemprop="articleBody" style="line-height: 1.4; position: relative; width: 606px;">
<div dir="ltr" trbidi="on">
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: center;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
முந்தைய பாகத்தில்&nbsp;while loop பானது ஒரு condition true வாக இருக்கும் வரையில் குறிப்பிட்ட statement களை திரும்பத் திரும்ப execute செய்யும் என்பதை பார்த்தோம் அல்லவா? அதனை சற்று நினைவுபடுத்தி பார்த்துவிட்டு மற்றவைகளை பார்ப்போம்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>WHILE&nbsp;</b>this_boolean_condition_is_true</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>BEGIN</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; execute these statements</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; your statements here</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>END</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இது எவ்வாறு வேலை செய்ததென்று பார்த்தோம்?</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<a href="" name="more"></a><br />step 1 : முதலில் this_boolean_condition_is_true என்பது true ஆக இருக்கிறதா? இல்லை false ஆக இருக்கிறதா? என்பது evaluate செய்யப்படுகிறது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br />step 2 : ஒருவேளை step 1 னுடைய result false ஆக இருந்தால் begin மற்றும் end டுக்கு நடுவில் இருக்கும் statement கள் execute செய்யப்படாது. end டுக்கு அடுத்துள்ள part க்கு control சென்று விடும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br />step 3: ஒருவேளை step 1 னுடைய result true ஆக இருந்தால் begin மற்றும் end டுக்கு நடுவில் இருக்கும் statement கள் execute செய்யப்படும். பின்னர் மீண்டும் step 1 க்கு control செல்லும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இதில் கவனிக்க வேண்டியது என்னவென்றால் இங்கு condition முதலில் evaluate செய்யப்பட்டு பின்னர் அதன் முடிவுக்கேற்ப statement டுகள் execute செய்யப்படுகின்றன.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
ஆனால் ஒரு சில சமயங்களில் இதை தலைகீழாக செய்யவேண்டிய சூழ்நிலை ஏற்படலாம். அதாவது statement டுகள் முதலில் execute செய்யப்பட்டு அதன் பின்னர் condition evaluate செய்யப்பட்டு அந்த condition true வாக இருக்கும் வரையில் மீண்டும் அந்த statement களை திரும்பத்திரும்ப execute செய்யவேண்டி வரும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
புரியும்படி சொல்வதானால் முதலில் சில காரியங்களை செய்து அதனால் ஏற்படும் பின்விளைவை ஆராய்ந்து அந்த விளைவுக்கு தக்கவாறு மேற்படி காரியங்களை மீண்டும் தொடர வேண்டுமா வேண்டாமா என்பதை முடிவு செய்யவேண்டி வரும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
உதாரணத்திற்கு, ஒன்றை கேட்டவுடன் உடனே வாங்கித்தரும் பெற்றோரும் உள்ளனர். பல தடவை மீண்டும் மீண்டும் கேட்டால்தான் வாங்கித்தரும் பெற்றோரும் உள்ளனர். அல்லது எத்தனை தடவை கேட்டாலும் வாங்கித்தராமல் இருக்கும் பெற்றோரும் உள்ளனர்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இப்போது உங்களுக்கு ஒரு மோட்டார் சைக்கிள்&nbsp; தேவைப்படுகிறதென்று வைத்துக்கொள்வோம். உங்கள் பெற்றோரிடம் கேட்கிறீர்கள். உடனே வாங்கித்தரவில்லை என்றால் என்ன செய்வீர்கள் திரும்பத்திரும்ப வாங்கிகேட்பீர்கள் தானே?</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
என்ன நடக்கும் என்பதை step by step ப்பாக பார்ப்போம். அப்போதுதான் எளிதில் விளங்கும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 1 : அம்மா! மோட்டார் சைக்கிள் எனக்கு வேண்டும். அத்தாவிடம் சொல்லி வாங்கித்தாங்க என்று கேட்கிறீர்கள்</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 2 : அம்மாவும் அத்தாவிடம் கேட்கிறார்</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 3 : அத்தா இப்போது முடியாது என்கிறார்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 4 : மோட்டார் சைக்கிள் கிடைக்காது போல இருக்கிறது, இன்னும் கொஞ்சம் அழுத்தமாக கேட்கவேண்டும் என்று முடிவு செய்கிறீர்கள். மீண்டும் step 1 க்கு போகிறீர்கள்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இங்கே முதலில் condition எதுவும் evaluate செய்யப்படவில்லை பார்த்தீர்களா? step 1 மற்றும் 2 ல் சில காரியங்கள் (statements execute) செய்யப்படுகிறது. அதன் பின்னர் step 3 யில் அதன் result தெரிகிறது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இப்பொழுது step 3 யில் கிடைத்த பதில் (result or condition) evaluate செய்யப்படுகிறது. அதன் அடிப்படையில் திரும்பவும் step 1 க்கு போகவேண்டுமா அல்லது வேண்டாமா என்பது தீர்மானிக்கப்படுகிறது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இதன் முடிவு எப்படி எல்லாம் இருக்கும்?</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>வாய்ப்பு 1:</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 3: அத்தா வாங்கித் தரலாம் என்கிறார்</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 4: மோட்டார் சைக்கிள் கிடைத்துவிடும் போல தெரிகிறது. மீண்டும் step 1 க்கு போகவேண்டாம் என்று தீர்மானிக்கிறீர்கள்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>வாய்ப்பு 2:</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 3:&nbsp;பொருளாதார வசதியைக் காட்டி அத்தா இப்போது முடியாது என்கிறார்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 4 : மோட்டார் சைக்கிள் கிடைக்காது போல இருக்கிறது, நிலைமையை உணராமல் இன்னும் கொஞ்சம் அழுத்தமாக கேட்கவேண்டும் என்று முடிவு செய்கிறீர்கள். மீண்டும் step 1 க்கு போகிறீர்கள்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>வாய்ப்பு 3:</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 3:&nbsp;பொருளாதார வசதியைக் காட்டி அத்தா இப்போது முடியாது என்கிறார்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
step 4 : மோட்டார் சைக்கிள் கிடைக்காது போல இருக்கிறது, நிலைமையை உணர்ந்து உங்கள் கோரிக்கையை கைவிட்டுவிடலாம் மீண்டும் step 1 க்கு போகவேண்டாம் என்று தீர்மானிக்கிறீர்கள்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
மேற்கண்ட உதாரணம் இயல்பாக நமது வாழ்வில் நடைபெறும் ஒன்று. என்னங்க! எல்லாத்துக்கும் இந்தமாதிரி உதாரணத்தை சொல்றீங்களே என்று நீங்கள் கேட்கலாம். இந்த மாதிரி உதாரணங்களை நாம் பார்ப்பதன் மூலம் ஒவ்வொரு செயலிலும் ஒரு லாஜிக் இருப்பதை காணலாம். முதலில் நமக்கு புரியவில்லை என்றால் எவ்வாறு ஒரு செயல் நடைபெறுகிறது என்பதை நாம் பட்டியல் போடவேண்டும். அவ்வாறு பட்டியல் போட்டால் அதில் உள்ள லாஜிக்கை புரிந்து கொள்ளலாம்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இந்த மாதிரி அற்ப செயல்களுக்கெல்லாம் நாம் பட்டியல் போட்டு லாஜிக்கை அவசியம் புரிந்துகொள்ளவேண்டுமா?. இதையெல்லாம் புரிந்துகொண்டால்தான் புரோகிராமிங் செய்யமுடியுமா என்று அடுத்த கேள்வி எழும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
ஆமாம் புரிந்துகொள்ள முயலுங்கள். நீங்கள் இதையெல்லாம் புரிந்து கொண்டால் உங்களால் மிகச்சிறப்பாக இயல்பாக புரோகிராமிங் செய்ய முடியும். மனப்பாடம் செய்யவேண்டிய அவசியம் இருக்காது. மனப்பாடம் செய்தது எப்போது வேண்டுமானாலும் மறந்து போகலாம்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
நீங்கள் புரோகிராமராக ஒரு வேலையில் சேர்ந்தால், for loop ஐ பயன்படுத்தி while loop பை பயன்படுத்தி if condition போட்டு function ஒன்றை எழுதி ஒரு புரோகிராம் செய்து தாருங்கள் என்று ஒருவரும் உங்களை கேட்கமாட்டார்கள்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
அல்லது find the biggest number, find the Fibonacci series, reverse the string என்றெல்லாம் கேட்கமாட்டார்கள். அப்படி கேட்பார்கள் என்றால் நாம் மனப்பாடம் பண்ணிகொள்ளலாம். ஆனால் வேலைக்கு சேர்ந்த பின்பு மண்டை காய்ந்து போகிற மாதிரி bus company ஐ நிர்வகிக்க ஒரு புரோகிராம் வேண்டும். school management program வேண்டும் என்று கேட்பார்கள்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இதையெல்லாம் நான் பள்ளியிலோ, கல்லூரியிலோ, கம்ப்யூட்டர் செண்டரிலோ படிக்கவில்லை என்று சொல்வீர்களா? சொன்னால் உங்கள் வேலை காலி!</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
சரி bus company க்கு ஒரு program வேண்டுமென்றால் நாமே கற்பனையாக ஒரு concept ஐ உருவாக்கி அதை புரோகிராமாக செய்து கொடுக்கமுடியுமா? நீங்கள் செய்தது bus company நடைமுறைக்கு ஒத்துவரவில்லை என்று உங்களையும் உங்கள் program மையும் ஓரங்கட்டிவிடுவார்கள்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
பின்னே என்னதான் செய்யவேண்டும்? பஸ் கம்பெனியில் அன்றாடம் என்னென்ன நடக்கிறது என்பதை உள்வாங்கி; கேள்விகள் கேட்டு; புரிந்துகொண்டதை அவர்களுக்கு விளக்கி; அதில் உங்களுக்கும் அவர்களுக்கும் ஏற்படும் சந்தேகங்களுக்கு விடைகண்டு; அதன்பிறகு நீங்கள் எழுதிக்கொடுக்கும் program இருக்கிறதே, அதன் மதிப்பே தனி.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
பஸ் கம்பெனியில் நடக்கும் ஒரு சின்ன விசயத்தை புரிந்துகொள்ளாமல் போனாலும் உங்கள் புரோகிராமில் ஒரு ஓட்டை விழுந்துவிடும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
இதையெல்லாம் நான் ஒரு புரோகிராமராக வேலைக்கு சேர்ந்த பின்பு பார்த்து கொள்கிறேன் என்பதை விட இப்பொழுதே நீங்களே அன்றாடம் நடக்கும் செயல்களை புரோகிராமாக மாற்ற முயற்சி செய்து கொண்டே இருக்கவேண்டும்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
அதற்கான பயிற்சியாகத்தான் உங்களுக்கு இங்கே உதாரணங்கள் கொடுக்கப்படுகின்றன. எனவே மேற்படி மோட்டார் சைக்கிள் வாங்கும் செயலை ஒரு புரோகிராமாக எழுத வேண்டும் . இதுதான் உங்களுக்கான பயிற்சி.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
பயிற்சியை தொடங்குவோம்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
மேற்கண்ட மோட்டார் சைக்கிள் உதாரணத்தில்&nbsp; 4 step புகள் இருக்கின்றன. அவை திரும்பத்திரும்ப செயல்படுத்தப்படுகின்றன. இதற்கு loop பயன்படும் என்பது விளங்குகிறது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
அடுத்ததாக இதை for loop பயன்படுத்தி எழுத முடியுமா என்று பார்க்கலாம். முடியாது. ஏனென்றால் இத்தனை தடவைதான் மோட்டார் சைக்கிள் வாங்கித்தருமாறு கேட்கவேண்டும் என்று முதலிலேயே தீர்மானித்துகொண்டா கேட்பீர்கள்? இல்லைதானே. எனவே for loop இதற்கு பயன்படாது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
அடுத்ததாக இதை while loop பயன்படுத்தி எழுத முடியுமா என்று பார்க்கலாம். முடியாது. ஏனென்றால் நாம் பார்த்த while loop ப்பில் condition முதலில் evaluate செய்யப்படவேண்டும். மோட்டார் சைக்கிள் கிடைக்கவி்ல்லையானால் என்பது condition. நமது செயலில் இந்த condition ஐ முதலில் போடமுடியாது. உங்களிடம் அப்பா மோட்டார் சைக்கிள் வாங்கித்தரமாட்டேன் என்று முதலில் கூறுவாரா என்ன?&nbsp;</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
கேட்டபிறகுதான் பதில் தருவார். எனவே இங்கே while loop ப்பும் சரிவராது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>WHILE&nbsp;</b>மோட்டார் சைக்கிள் கிடைக்கவி்ல்லை மீண்டும் கேட்கவும்</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>BEGIN</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; step 1 : அம்மா! மோட்டார் சைக்கிள் எனக்கு வேண்டும். அத்தாவிடம் சொல்லி வாங்கித்தாங்க என்று கேட்கிறீர்கள்</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; step 2 : அம்மாவும் அத்தாவிடம் கேட்கிறார்<br />&nbsp; step 3 : அத்தா இப்போது முடியாது என்கிறார்.<br />&nbsp;step 4 : மோட்டார் சைக்கிள் கிடைக்காது போல இருக்கிறது, இன்னும் கொஞ்சம் அழுத்தமாக கேட்கவேண்டும் என்று முடிவு செய்கிறீர்கள். மீண்டும் step 1 க்கு போகவேண்டும். அல்லது கிடைத்துவிட்டால் step 1 க்கு போகவேண்டாம்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>END</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
நமது செயலை while loop ப்பில் இப்படித்தான் போடமுடியும். இது சரிவராது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
வேறு உபாயம் இருக்கிறதா? தேடிப்பார்த்ததில் do..while loop இருக்கிறதே!</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /><b>Do..While loop பின் syntax</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /><b>DO</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; execute these statements</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; your statements here</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>WHILE&nbsp;</b>this_boolean_condition_is_true</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div class="separator" style="background-color: #fefdfa; clear: both; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhNUPusqBMJzXnBiApNKVGTu5hwK2mkOdkEfyUejBJxOHWLa65fjZmw4OkJWr-zxRNOV7SJBrtfXT86Mj6bIz36esol4MSzMShXpKd9dOy7qHaHEQN4S5FuxOrlN7QvLIA285RHKdMVlae_/s1600/do+while+loop+structure.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="do while loop example, mohamed riyadul faridh, j.m.r. faridh, முஹம்மது ரியாதுல் ஃபரீத், முஹம்மது ரியாதுல் பரீத், முகம்மது" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhNUPusqBMJzXnBiApNKVGTu5hwK2mkOdkEfyUejBJxOHWLa65fjZmw4OkJWr-zxRNOV7SJBrtfXT86Mj6bIz36esol4MSzMShXpKd9dOy7qHaHEQN4S5FuxOrlN7QvLIA285RHKdMVlae_/s320/do+while+loop+structure.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="210" /></a></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>DO</b></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; step 1 : அம்மா! மோட்டார் சைக்கிள் எனக்கு வேண்டும். அத்தாவிடம் சொல்லி வாங்கித்தாங்க என்று கேட்கிறீர்கள்</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
&nbsp; step 2 : அம்மாவும் அத்தாவிடம் கேட்கிறார்<br />&nbsp; step 3 : அத்தா இப்போது முடியாது என்கிறார்.<br />&nbsp;step 4 : மோட்டார் சைக்கிள் கிடைக்காது போல இருக்கிறது, இன்னும் கொஞ்சம் அழுத்தமாக கேட்கவேண்டும் என்று முடிவு செய்கிறீர்கள். மீண்டும் step 1 க்கு போகவேண்டும். அல்லது கிடைத்துவிட்டால் step 1 க்கு போகவேண்டாம்.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<b>WHILE&nbsp;</b>இன்னொரு முறை கேட்கனுமா?</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div class="separator" style="background-color: #fefdfa; clear: both; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi-s-B-Erkda8zhTJV9PTv7NrZqxMeVwMeWrUum_55NTeH-2077zZTcxs1qREh8inksRxwYwlS-_nJf_t3VvbZNAwARBsWf0tayd2-1cAe0cTElCmQMDOK3pM9oPXXfRZkxtZykb7_RYzAp/s1600/do+while+loop+example.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="do while loop example, mohamed riyadul faridh, j.m.r. faridh, முகம்மது ரியாதுல் ஃபரீத், முகம்மது ரியாதுல் பரீத், முகமது ரியாதுல் பரீத்" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi-s-B-Erkda8zhTJV9PTv7NrZqxMeVwMeWrUum_55NTeH-2077zZTcxs1qREh8inksRxwYwlS-_nJf_t3VvbZNAwARBsWf0tayd2-1cAe0cTElCmQMDOK3pM9oPXXfRZkxtZykb7_RYzAp/s320/do+while+loop+example.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="278" /></a></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
condition true / false என்பது இறுதியில் evaluate செய்யப்படுவதால் ஒரு தடவையாவது உங்கள் கோரிக்கையை execute செய்ய do while loop உதவுகிறது.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
The difference between do..while and while..do loop is that do..while evaluates its expression at the bottom of the loop instead of the top. Therefore, the statements within the do block are always executed at least once.</div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
<br /></div>
<div style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; text-align: justify;">
புரிந்ததா?</div>
<div>
<br /></div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/4235513249994285043/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/while-loop_7.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4235513249994285043'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/4235513249994285043'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/while-loop_7.html' title='While Loop பில் பல ரகம்'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhNUPusqBMJzXnBiApNKVGTu5hwK2mkOdkEfyUejBJxOHWLa65fjZmw4OkJWr-zxRNOV7SJBrtfXT86Mj6bIz36esol4MSzMShXpKd9dOy7qHaHEQN4S5FuxOrlN7QvLIA285RHKdMVlae_/s72-c/do+while+loop+structure.jpg" height="72" width="72"/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-3691376985285892436.post-5594671906436917109</id><published>2013-08-07T05:28:00.000-07:00</published><updated>2013-08-07T05:28:04.830-07:00</updated><title type='text'>While loop என்றால் என்ன?</title><content type='html'><div dir="ltr" style="text-align: left;" trbidi="on">
<div class="post-body entry-content" id="post-body-3976572279288618476" itemprop="articleBody" style="background-color: #fefdfa; color: #333333; font-family: Arial, Tahoma, Helvetica, FreeSans, sans-serif; font-size: 13px; line-height: 18px; position: relative; width: 606px;">
<div dir="ltr" trbidi="on">
<div style="text-align: justify;">
<div style="text-align: center;">
<span style="font-size: 13px; line-height: 18px; text-align: justify;">&nbsp;</span></div>
முந்தைய பதிவில்&nbsp;for loop ஐ பற்றி பார்த்தோம் அல்லவா. இந்த பதிவில் while loop&nbsp; ஐ பற்றி பார்ப்போம்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
ஒரு condition true வாக இருக்கும் வரையில் குறிப்பிட்ட statement களை திரும்பத்திரும்ப execute செய்ய while loop பயன்படுகிறது.<br /><br />இதையேதான் for loop செய்கிறதே, பின்பு அதற்கும் இதற்கும் என்ன வித்தியாசம் என்று கேட்கிறீர்களா? வித்தியாசம் இருக்கிறது. For loop வேலை செய்வதற்கு ஆரம்ப எண்ணும் முடிவு எண்ணும் அவசியம் தேவை. ஆனால் while loop பிற்கு ஆரம்ப எண், முடிவு எண் அவசியமில்லை, தேவையானால் வேறுவகையில் பயன்படுத்திக் கொள்ளலாம்.<br /><a href="" name="more"></a><br /><b>While loop பின் syntax</b></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
<b>WHILE&nbsp;</b>this_boolean_condition_is_true</div>
<div style="text-align: justify;">
<b>BEGIN</b></div>
<div style="text-align: justify;">
&nbsp; execute these statements</div>
<div style="text-align: justify;">
&nbsp; your statements here</div>
<div style="text-align: justify;">
<b>END</b></div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
மேலே இருக்கும் while loop எப்படி வேலை செய்கிறதென்பதை இனி பார்ப்போம்.<br /><br /><div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiVs4sNKpSuU4RUSP0w7NyJCZ1JTY40F8AZOVIXEBFX_B7jV5xVbIAvuYLxm2rKhZYQ_4Iu8t9Uy-m-AzV5NPQ-irjN5IMJlXQu15UTQtUaYfVFtHPGNnWB1NEKPEVxWNnQreN5zIAAs81I/s1600/while_loop.jpg" imageanchor="1" style="color: #7d181e; margin-left: 1em; margin-right: 1em; text-decoration: none;"><img alt="while loop, mohamed riyadul faridh, new era technology, do while loop" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiVs4sNKpSuU4RUSP0w7NyJCZ1JTY40F8AZOVIXEBFX_B7jV5xVbIAvuYLxm2rKhZYQ_4Iu8t9Uy-m-AzV5NPQ-irjN5IMJlXQu15UTQtUaYfVFtHPGNnWB1NEKPEVxWNnQreN5zIAAs81I/s320/while_loop.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="200" /></a></div>
</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
step 1 : முதலில் this_boolean_condition_is_true என்பது true ஆக இருக்கிறதா? இல்லை false ஆக இருக்கிறதா? என்பது evaluate செய்யப்படுகிறது.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
step 2 : ஒருவேளை step 1 னுடைய result false ஆக இருந்தால் begin மற்றும் end டுக்கு நடுவில் இருக்கும் statement கள் execute செய்யப்படாது. end டுக்கு அடுத்துள்ள part க்கு control சென்று விடும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
step 3: ஒருவேளை step 1 னுடைய result true ஆக இருந்தால் begin மற்றும் end டுக்கு நடுவில் இருக்கும் statement கள் execute செய்யப்படும். பின்னர் மீண்டும் step 1 க்கு control செல்லும்.</div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
இப்படியாக this_boolean_condition_is_true என்பது true ஆக இருக்கும் வரை while loop தனக்குள் இருக்கும் statement களை திரும்பத்திரும்ப execute செய்துகொண்டேயிருக்கும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
இப்படியே execute செய்துகொண்டிருந்தால் endless loop ஆக ஆகிவிடுமே? program hang ஆக விடுமே என்ற கேள்வி எழும். உண்மைதான் for loop ஐ போன்று இத்தனை முறை execute செய்துவிட்டு வெளியேறிவிடு என்று இதில் நாம் எழுதப்போவதில்லை. பிறகு எப்படி while loop முடிவுக்கு வருகிறது?</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
while loop ல் statement எழுதுகிறோம் அல்லவா? அங்குதான் while loop பின் முடிவு எல்லை எதுவென்று தீர்மானிக்கப்படுகிறது.<br /><br />அதாவது while loop execute ஆகினால் ஏதாவது ஒன்று நடக்கும் அல்லவா? அந்த ஒன்றின் அடிப்படையில் while loop ஐ தொடர்வதா வேண்டாமா என்பதை நம்மால் தீர்மானிக்க முடியும்.<br /><br />உதாரணத்திற்கு உங்கள் ஊரில் தண்ணீர் பஞ்சம் வந்துவிட்டதென்று வைத்துக்கொள்வோம். பிரச்சினை தீர&nbsp; கிணறு ஒன்று வெட்ட முடிவாகிவிட்டது. ஊரில் நீங்கள்தான் படித்தபிள்ளை என்று கிணறு வெட்ட உங்களிடம் plan கேட்கிறார்கள். இப்பொழுது நீங்கள் algorithm எழுதவேண்டும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
எப்படி எழுதுவீர்கள்?</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
1. கிணறு வெட்ட வேண்டிய இடத்தை தேர்வு செய்யவும்.</div>
<div style="text-align: justify;">
2. இத்தனை அடி ஆழம் கிணறு வெட்டவும்.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
</div>
<div style="text-align: justify;">
இந்த பிளானை கொடுத்தவுடன், எத்தனை அடி வெட்டனும் தம்பின்னு கேட்பார்கள். நீங்க 10 அடின்னு சொல்றீங்க. 10 அடி ஆழத்தில் தண்ணீர் கிடைத்துவிடும் என்று எப்படி தம்பி சொல்றீங்க? ஒருவேளை கிடைக்கலைன்னா என்ன செய்யறது?</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
அவர்கள் கேள்வி நியாயமாக இருக்கிறது.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
10 அடிதான் கிணறு வெட்ட வேண்டும் என்பதை முன்னரே தீர்மானிக்க இயலாது என்பதுதான் யதார்த்தமான உண்மை (ஆனால் for loop புக்கு முடிவு எல்லை ஆரம்பத்திலேயே தீர்மானிக்கப்பட்டுவிடுகிறது என்பதை கவனத்தில் கொள்ளவும்). பின்னே இந்த மாதிரி வேலைகளுக்கு முடிவு எல்லையை எப்படி வரையறுப்பது?</div>
<div style="text-align: justify;">
<br />லாஜிக் இல்லாமல் எவராலும் கிணறு வெட்ட முடியாது. சரி யோசிப்போம்...<br /><br />சரி 20 அடி என்று மாற்றுவீர்களா? இதிலும் அதே பிரச்சனை உள்ளது.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
பின்னே எப்படித்தான் கிணறு வெட்ட algorithm எழுதுவது?</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
1. கிணறு வெட்ட வேண்டிய இடத்தை தேர்வு செய்யவும்.</div>
<div style="text-align: justify;">
2. தண்ணீர் கிடைக்கும் வரை கிணறு வெட்டவும்.<br /><br />சூப்பர்! இதைத்தான் யதார்த்தமாக யோசிப்பது என்பது.<br /><br />மேலோட்டமாக இருக்கும் 2 ஆவது step ல் பல விசயங்கள் அடங்கியுள்ளன. அவற்றை விவரித்து எழுதினால் தான் while loop ஐ பற்றி நன்றாக அறிந்துகொள்ளமுடியும்.<br /><br />எப்படி விவரித்து எழுதுவது?<br />யோசியுங்கள்....<br /><br /><div>
1. கிணறு வெட்ட வேண்டிய இடத்தை தேர்வு செய்யவும்.</div>
2. தண்ணீர் கிடைக்கும் வரை<br />&nbsp; 2.1. பள்ளம் தோண்டவும்<br />&nbsp; 2.2. ஒருவேளை தண்ணீர் கிடைத்து விட்டால் தோண்டுவதை நிறுத்தவும்<br />&nbsp;2.3 ஒருவேளை 200 அடி ஆழம் வரை தோண்டியும் தண்ணீர் கிடைக்கவில்லையென்றால் தோண்டுவதை நிறுத்தவும்<br /><br />எவ்வளவு எதார்த்தமான வழிமுறை பார்த்தீர்களா? இதில் ஏதாவது கற்பனை இருக்கிறதா?<br /><br />அவ்வளவுதான் இப்போது லாஜிக் கிடைத்துவிட்டது.</div>
<div style="text-align: justify;">
<br /></div>
<div style="text-align: justify;">
இதை while loop பயன்படுத்தி எழுதுவோமா?</div>
<div style="text-align: justify;">
<br /><b>while</b>&nbsp; தண்ணீர் கிடைக்கும் வரை<b>&nbsp;</b><br /><b>begin</b><br />&nbsp;&nbsp;&nbsp; பள்ளம் தோண்டவும்<br />&nbsp;&nbsp;&nbsp; ஒருவேளை தண்ணீர் கிடைத்து விட்டால் தோண்டுவதை நிறுத்தவும்<br />&nbsp; ஒருவேளை 200 அடி தோண்டியும் தண்ணீர் கிடைக்கவில்லையென்றால் தோண்டுவதை நிறுத்தவும்<br /><b>end</b><br /><div>
<br />இங்கு 200 அடி என்பது எங்கள் ஊர் மக்கள் எவ்வளவு அடி அதிகபட்சம் வெட்டுவார்கள் என்பதை தெரிவித்ததால் அப்படி போட்டுள்ளேன். மற்றபடி அவரவர் தேவைக்கேற்ப முடிவு எல்லை மாறுபடும்.<br /><br /><div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhrWNjM5NT3yaNJKWTNjhqryOYuh7qSqqnFsJnhkoSV31wvkR-PBQSVPzSHgkxLumwTRqeazgJJDVb1LI1V8aE6JsxzjkrKNW7d_2P93L5kpqIEBB0qxXiQn5Dn0vIXm1aBlUEBhs_hGjOq/s1600/while_loop_example.jpg" imageanchor="1" style="color: #d52a33; margin-left: 1em; margin-right: 1em;"><img alt="while loop example, how while loop works, j.m.r.faridh" border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhrWNjM5NT3yaNJKWTNjhqryOYuh7qSqqnFsJnhkoSV31wvkR-PBQSVPzSHgkxLumwTRqeazgJJDVb1LI1V8aE6JsxzjkrKNW7d_2P93L5kpqIEBB0qxXiQn5Dn0vIXm1aBlUEBhs_hGjOq/s320/while_loop_example.jpg" style="-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; background-color: white; background-position: initial initial; background-repeat: initial initial; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-top-left-radius: 5px; border-top-right-radius: 5px; border: 1px solid rgb(204, 204, 204); box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 20px; padding: 8px; position: relative;" title="" width="239" /></a></div>
<br /><br />இப்பொழுது while loop நமது வாழ்வில் எப்படி பயன்படுத்தப்படுகிறது என்பது தெரிகிறதா? இது ஒரு உதாரணம்தான் இன்னும் நிறைய உதாரணங்கள் இருக்கின்றன. விரிவஞ்சி இதை மட்டும் சொல்கிறேன்.<br /><br />இந்த மாதிரி விசயத்துக்கு for loop சரிப்பட்டு வராது என்பது இப்பொழுது உங்களுக்கு புரிந்திருக்கும் என்று நம்புகின்றேன்.<br /><br />while loop ஐ பற்றி தெரிந்துகொள்ள இன்னும் நிறைய விசயங்கள் உள்ளன. அவற்றை அடுத்த பாகத்தில் பார்ப்போம்.</div>
</div>
</div>
</div>
</div>
</content><link rel='replies' type='application/atom+xml' href='http://tamilprogramminng.blogspot.com/feeds/5594671906436917109/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/while-loop.html#comment-form' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5594671906436917109'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/3691376985285892436/posts/default/5594671906436917109'/><link rel='alternate' type='text/html' href='http://tamilprogramminng.blogspot.com/2013/08/while-loop.html' title='While loop என்றால் என்ன?'/><author><name>Unknown</name><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='https://img1.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiVs4sNKpSuU4RUSP0w7NyJCZ1JTY40F8AZOVIXEBFX_B7jV5xVbIAvuYLxm2rKhZYQ_4Iu8t9Uy-m-AzV5NPQ-irjN5IMJlXQu15UTQtUaYfVFtHPGNnWB1NEKPEVxWNnQreN5zIAAs81I/s72-c/while_loop.jpg" height="72" width="72"/><thr:total>0</thr:total></entry></feed>
If you would like to create a banner that links to this page (i.e. this validation result), do the following:
Download the "valid Atom 1.0" banner.
Upload the image to your own server. (This step is important. Please do not link directly to the image on this server.)
Add this HTML to your page (change the image src
attribute if necessary):
If you would like to create a text link instead, here is the URL you can use: