<?xml version="1.0" encoding="UTF-8"?> <rss version="2.0" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" ><channel><title>وبلاگ سعید زبردست &#187; برنامه نویسی</title> <atom:link href="http://zebardast.ir/category/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%db%8c%d8%b3%db%8c/feed/" rel="self" type="application/rss+xml" /><link>http://zebardast.ir</link> <description>دسته نوشته ها و مقالاتی در زمینه علوم کامپیوتر و تجربیات شخصی</description> <lastBuildDate>Fri, 18 May 2012 15:59:30 +0000</lastBuildDate> <language>fa</language> <sy:updatePeriod>hourly</sy:updatePeriod> <sy:updateFrequency>1</sy:updateFrequency> <generator>http://wordpress.org/?v=3.3.2</generator><image><title>وبلاگ سعید زبردست</title> <url>http://0.gravatar.com/avatar/9fb25dddd365836466bd8051be993fa8.png?s=48</url><link>http://zebardast.ir</link> </image> <item><title>معرفی و آموزش پیاده‌سازی Apache Lucene</title><link>http://zebardast.ir/%d9%85%d8%b9%d8%b1%d9%81%db%8c-%d9%88-%d8%a2%d9%85%d9%88%d8%b2%d8%b4-%d9%be%db%8c%d8%a7%d8%af%d9%87%e2%80%8c%d8%b3%d8%a7%d8%b2%db%8c-apache-lucene/</link> <comments>http://zebardast.ir/%d9%85%d8%b9%d8%b1%d9%81%db%8c-%d9%88-%d8%a2%d9%85%d9%88%d8%b2%d8%b4-%d9%be%db%8c%d8%a7%d8%af%d9%87%e2%80%8c%d8%b3%d8%a7%d8%b2%db%8c-apache-lucene/#comments</comments> <pubDate>Sat, 14 Apr 2012 14:55:47 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[برنامه نویسی]]></category> <category><![CDATA[برنامه نویسی وب]]></category> <category><![CDATA[جاوا]]></category> <category><![CDATA[نرم افزار آزاد و متن باز]]></category> <category><![CDATA[Apache Lucene]]></category> <category><![CDATA[جستجو]]></category> <category><![CDATA[خزنده وب]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1865</guid> <description><![CDATA[سلام، — Apache Lucene حدود یک سال و نیم قبل در مطلبی به معرفی خزنده‌های وب (Web crawlers) و آموزش راه اندازی یک خزنده وب ساده به زبان جاوا پرداختم. در طول این مدت افراد بسیاری در مورد خزنده‌های وب با من تماس گرفتند و سوالات مختلفی در مورد این خزنده‌ها داشتند. در این مطلب [...] مطلب مرتبطی یافت نشد.]]></description> <content:encoded><![CDATA[<p>سلام،</p><div class="autocap alignleft" style="width: 300px;"><div><img src="http://zebardast.ir/wp-content/uploads/2012/03/Apache-Lucene.png" alt="" title="Apache Lucene" width="300" height="46" class=" size-full wp-image-1901" /><p class="autocap-text"><span class="hide">— </span>Apache Lucene</p></div></div><p>حدود یک سال و نیم قبل در مطلبی به <a href="http://zebardast.ir/%D8%AE%D8%B2%D9%86%D8%AF%D9%87-%D9%88%D8%A8-web-crawler/" title="خزنده وب (Web Crawler)">معرفی خزنده‌های وب (Web crawlers)</a> و آموزش راه اندازی یک خزنده وب ساده به زبان جاوا پرداختم. در طول این مدت افراد بسیاری در مورد خزنده‌های وب با من تماس گرفتند و سوالات مختلفی در مورد این خزنده‌ها داشتند. در این مطلب به معرفی و آموزش Apache Lucene که به منظور جستجو فایل‌های متین استفاده می شود، می پردازم. همچنین در آینده به بررسی ۳ محصول Hadoop, Apache Solr و Apache Nutch خواهم پرداخت.</p><h3>Apache Lucene</h3><p>آپاچی لوسن کتابخانه ای برای راه اندازی موتورهای جستجوی متن می باشد. این کتابخانه آزاد بوده و تحت لایسنس Apache Licene 2.0 منتشر می شود. این کتابخانه به زبان جاوا (Java) نوشته شده و سپس به زبان های Delphi, Perl, C#, C++, Python, Ruby, و PHP پیاده سازی (پورت) شده است.<br /> این کتابخانه این امکان را برای شما فراهم می آورد تا هر نوع موتور جستجوی متنی مانند موتور جستوی وب، لوکال (محلی) ویا فقط ویژه یک وب سایت را ایجاد نمایید. در نظر داشته باشید که Apache Lucene فقط برای جستجو استفاده می‌شود و برای جمع‌آوری اطلاعات و تحلیل آن‌ها نیاز به ابزارهای دیگری مانند Solr و Nutch دارید.<br /> برای دریافت این کتابخانه به <a href="https://lucene.apache.org/core/downloads.html" title="دانلود کتابخانه آپاچی لوسن" target="_blank">صفحه دانلود آپاچی لوسن</a> مراجعه نمایید. همچنین می توانید نسخه فعلی (۳.۶.۰) را از آدرس زیر دریافت نمایید:<br /> • <a href="http://apache.mirror.nexicom.net/lucene/java/3.6.0/lucene-3.6.0.zip" title="دانلود کتابخانه آپاچی لوسن نسخه ۳.۶.۰" target="_blank">دانلود کتابخانه آپاچی لوسن نسخه ۳.۶.۰</a></p><h3>استفاده از کتابخانه Apache Lucene</h3><p>در ادامه مراحل مختلف برای آماده‌سازی و انجام جستجو را بررسی کرده و در انتها سورس کامل این کلاس را مشاهده خواهید کرد.</p><h4>مرحله اول: ایندکس کردن اطلاعات</h4><p>قبل از هر چیز شما باید اطلاعاتی را که قصد جستجو در آن‌ها را دارید ایندکس نمایید. ایندکس کردن اطلاعات فواید زیادی دارد که یکی از مهم‌ترین آن‌ها مرتب‌سازی و افزایش سرعت جستجو است.<br /> ایندکس اطلاعات در لوسن توسط دو کلاس Document و Field صورت می پذیرد. Document سند شما و Field اطلاعات مرتبط با سند مانند عنوان، محتوا و&#8230;  است. این وظیفه شماست که اطلاعات خود از جمله رشته‌ها، انواع فایل‌ها، اطلاعات ذخیره شده در پایگاه داده و&#8230; را به کلاس Document تبدیل و ایندکس نمایید. در زیر تعامل Index, Document و Field را مشاهده می کنید:<br /><center></p><table class="ltr" cellpadding="5" bgcolor="lightblue"><tbody><tr><td align="left" colspan="2">&nbsp;Index&nbsp;</td></tr><tr><td><table cellpadding="10" bgcolor="lightgreen"><tbody><tr><td>Document 1</p><table cellpadding="5" bgcolor="yellow"><tbody><tr><td>Field A (name/value)</td></tr></tbody></table><p></p><table cellpadding="5" bgcolor="yellow"><tbody><tr><td>Field B (name/value)</td></tr></tbody></table></td></tr></tbody></table></td><td><table cellpadding="10" bgcolor="lightgreen"><tbody><tr><td>Document 2</p><table cellpadding="5" bgcolor="yellow"><tbody><tr><td>Field A (name/value)</td></tr></tbody></table><p></p><table cellpadding="5" bgcolor="yellow"><tbody><tr><td>Field B (name/value)</td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><p></center></p><p>بعد از آماده سازی Document باید توسط کلاس IndexWriter، ایندکس را ذخیره می کنیم. پارامتر اول در فراخوانی IndexWriter دایکتوری ذخیره‌سازی ایندکس را مشاهده می‌کند.<br /> با کدهای زیر چند عبارت را در حافظه دسترسی تصادفی (RAM) ذخیره کردیم:</p><pre class="brush: java; title: ; notranslate">
Directory index = new RAMDirectory();
IndexWriterConfig config = new IndexWriterConfig(Version.LUCENE_36, analyzer);

IndexWriter w = new IndexWriter(index, config);
addDoc(w, &quot;Lucene in Action&quot;);
addDoc(w, &quot;Lucene for Dummies&quot;);
addDoc(w, &quot;Managing Gigabytes&quot;);
addDoc(w, &quot;The Art of Computer Science&quot;);
w.close();
</pre><p>متد addDoc رشته‌ها را به ایندکس اضافه می کند:</p><pre class="brush: java; title: ; notranslate">
private static void addDoc(IndexWriter w, String value) throws IOException {
    Document doc = new Document();
    doc.add(new Field(&quot;title&quot;, value, Field.Store.YES, Field.Index.ANALYZED));
    w.addDocument(doc);
  }
}
</pre><h4>مرحله دوم: ایجاد کوئری (Query)</h4><p>در این برنامه ما عبارت مورد نظر برای جستجو را از ورودی (stdin) دریافت می‌کنیم:</p><pre class="brush: java; title: ; notranslate">
String querystr = args.length &gt; 0 ? args[0] : &quot;lucene&quot;;
Query q = new QueryParser(Version.LUCENE_36, &quot;title&quot;, analyzer).parse(querystr);
</pre><h4>مرحله سوم: انجام جستجو</h4><p>در این مرحله کوئری (جستار؟) ساخته شده را بر روی ایندکس جستجو می کنیم. همچنین از کلاس TopScoreDocCollector برای بدست آوردن ۱۰ نتیجه مرتبط‌تر استفاده کرده ایم:</p><pre class="brush: java; title: ; notranslate">
int hitsPerPage = 10;
IndexReader reader = IndexReader.open(index);
IndexSearcher searcher = new IndexSearcher(reader);
TopScoreDocCollector collector = TopScoreDocCollector.create(hitsPerPage, true);
searcher.search(q, collector);
ScoreDoc[] hits = collector.topDocs().scoreDocs;
</pre><h4>مرحله چهارم: مشاهده نتایج</h4><p>در انتها نتایج بدست آمده را نمایش می‌دهیم:</p><pre class="brush: java; title: ; notranslate">
System.out.println(&quot;Found &quot; + hits.length + &quot; hits.&quot;);
for(int i=0;i&lt;hits.length;++i) {
    int docId = hits[i].doc;
    Document d = searcher.doc(docId);
    System.out.println((i + 1) + &quot;. &quot; + d.get(&quot;title&quot;));
}
</pre><p>همین!</p><h3>کلاس HelloLucene</h3><p>در زیر کلاس HelloLucene را یکجا مشاهده می فرمایید:</p><pre class="brush: java; title: ; notranslate">
import java.io.IOException;

import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.IndexWriterConfig;
import org.apache.lucene.queryParser.ParseException;
import org.apache.lucene.queryParser.QueryParser;
import org.apache.lucene.search.*;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.RAMDirectory;
import org.apache.lucene.util.Version;

public class HelloLucene {
    public static void main(String[] args) throws IOException, ParseException {
        // 0. Specify the analyzer for tokenizing text.
        //    The same analyzer should be used for indexing and searching
        StandardAnalyzer analyzer = new StandardAnalyzer(Version.LUCENE_36);

        // 1. create the index
        Directory index = new RAMDirectory();

        IndexWriterConfig config = new IndexWriterConfig(Version.LUCENE_36, analyzer);

        IndexWriter w = new IndexWriter(index, config);
        addDoc(w, &quot;Lucene in Action&quot;);
        addDoc(w, &quot;Lucene for Dummies&quot;);
        addDoc(w, &quot;Managing Gigabytes&quot;);
        addDoc(w, &quot;The Art of Computer Science&quot;);
        w.close();

        // 2. query
        String queryStr = args.length &gt; 0 ? args[0] : &quot;lucene&quot;;

        // the &quot;title&quot; arg specifies the default field to use
        // when no field is explicitly specified in the query.
        Query q = new QueryParser(Version.LUCENE_35, &quot;title&quot;, analyzer).parse(queryStr);

        // 3. search
        int hitsPerPage = 10;
        IndexReader reader = IndexReader.open(index);
        IndexSearcher searcher = new IndexSearcher(reader);
        TopScoreDocCollector collector = TopScoreDocCollector.create(hitsPerPage, true);
        searcher.search(q, collector);
        ScoreDoc[] hits = collector.topDocs().scoreDocs;

        // 4. display results
        System.out.println(&quot;Found &quot; + hits.length + &quot; hits.&quot;);
        for (int i = 0; i &lt; hits.length; ++i) {
            int docId = hits[i].doc;
            Document d = searcher.doc(docId);
            System.out.println((i + 1) + &quot;. &quot; + d.get(&quot;title&quot;));
        }

        // searcher can only be closed when there
        // is no need to access the documents any more.
        searcher.close();
    }

    private static void addDoc(IndexWriter w, String value) throws IOException {
        Document doc = new Document();
        doc.add(new Field(&quot;title&quot;, value, Field.Store.YES, Field.Index.ANALYZED));
        w.addDocument(doc);
    }
}
</pre><h3>منابع</h3><ul class="ltr"><li><a href="http://www.lucenetutorial.com/lucene-in-5-minutes.html" title="Lucene in 5 minutes" target="_blank">Lucene in 5 minutes</a></li><li><a href="www.javacodegeeks.com/2010/05/introduction-to-apache-lucene-for-full.html" title="An Introduction to Apache Lucene for Full-Text Search" target="_blank">An Introduction to Apache Lucene for Full-Text Search</a></li><li><a href="www.avajava.com/tutorials/lessons/how-do-i-use-lucene-to-index-and-search-text-files.html" title="How do I use Lucene to index and search text files?" target="_blank">How do I use Lucene to index and search text files?</a></li><li><a href="www.javacodegeeks.com/2010/05/did-you-mean-feature-lucene-spell.html" title=""Did you mean" feature with Apache Lucene Spell-Checker" target="_blank">&#8220;Did you mean&#8221; feature with Apache Lucene Spell-Checker</a></li><li><a href="http://oak.cs.ucla.edu/cs144/projects/lucene/index.html" title="A Short Introduction to Lucene" target="_blank">A Short Introduction to Lucene</a></li></ul><p>شاد و پیروز باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25b1%25d9%2581%25db%258c-%25d9%2588-%25d8%25a2%25d9%2585%25d9%2588%25d8%25b2%25d8%25b4-%25d9%25be%25db%258c%25d8%25a7%25d8%25af%25d9%2587%25e2%2580%258c%25d8%25b3%25d8%25a7%25d8%25b2%25db%258c-apache-lucene%2F&amp;linkname=%D9%85%D8%B9%D8%B1%D9%81%DB%8C%20%D9%88%20%D8%A2%D9%85%D9%88%D8%B2%D8%B4%20%D9%BE%DB%8C%D8%A7%D8%AF%D9%87%E2%80%8C%D8%B3%D8%A7%D8%B2%DB%8C%20Apache%20Lucene" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25b1%25d9%2581%25db%258c-%25d9%2588-%25d8%25a2%25d9%2585%25d9%2588%25d8%25b2%25d8%25b4-%25d9%25be%25db%258c%25d8%25a7%25d8%25af%25d9%2587%25e2%2580%258c%25d8%25b3%25d8%25a7%25d8%25b2%25db%258c-apache-lucene%2F&amp;linkname=%D9%85%D8%B9%D8%B1%D9%81%DB%8C%20%D9%88%20%D8%A2%D9%85%D9%88%D8%B2%D8%B4%20%D9%BE%DB%8C%D8%A7%D8%AF%D9%87%E2%80%8C%D8%B3%D8%A7%D8%B2%DB%8C%20Apache%20Lucene" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25b1%25d9%2581%25db%258c-%25d9%2588-%25d8%25a2%25d9%2585%25d9%2588%25d8%25b2%25d8%25b4-%25d9%25be%25db%258c%25d8%25a7%25d8%25af%25d9%2587%25e2%2580%258c%25d8%25b3%25d8%25a7%25d8%25b2%25db%258c-apache-lucene%2F&amp;linkname=%D9%85%D8%B9%D8%B1%D9%81%DB%8C%20%D9%88%20%D8%A2%D9%85%D9%88%D8%B2%D8%B4%20%D9%BE%DB%8C%D8%A7%D8%AF%D9%87%E2%80%8C%D8%B3%D8%A7%D8%B2%DB%8C%20Apache%20Lucene" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25b1%25d9%2581%25db%258c-%25d9%2588-%25d8%25a2%25d9%2585%25d9%2588%25d8%25b2%25d8%25b4-%25d9%25be%25db%258c%25d8%25a7%25d8%25af%25d9%2587%25e2%2580%258c%25d8%25b3%25d8%25a7%25d8%25b2%25db%258c-apache-lucene%2F&amp;linkname=%D9%85%D8%B9%D8%B1%D9%81%DB%8C%20%D9%88%20%D8%A2%D9%85%D9%88%D8%B2%D8%B4%20%D9%BE%DB%8C%D8%A7%D8%AF%D9%87%E2%80%8C%D8%B3%D8%A7%D8%B2%DB%8C%20Apache%20Lucene" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25b1%25d9%2581%25db%258c-%25d9%2588-%25d8%25a2%25d9%2585%25d9%2588%25d8%25b2%25d8%25b4-%25d9%25be%25db%258c%25d8%25a7%25d8%25af%25d9%2587%25e2%2580%258c%25d8%25b3%25d8%25a7%25d8%25b2%25db%258c-apache-lucene%2F&amp;title=%D9%85%D8%B9%D8%B1%D9%81%DB%8C%20%D9%88%20%D8%A2%D9%85%D9%88%D8%B2%D8%B4%20%D9%BE%DB%8C%D8%A7%D8%AF%D9%87%E2%80%8C%D8%B3%D8%A7%D8%B2%DB%8C%20Apache%20Lucene" id="wpa2a_2">اشتراک‌گذاری</a></p><p>مطلب مرتبطی یافت نشد.</p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d9%85%d8%b9%d8%b1%d9%81%db%8c-%d9%88-%d8%a2%d9%85%d9%88%d8%b2%d8%b4-%d9%be%db%8c%d8%a7%d8%af%d9%87%e2%80%8c%d8%b3%d8%a7%d8%b2%db%8c-apache-lucene/feed/</wfw:commentRss> <slash:comments>6</slash:comments> </item> <item><title>راهنمای سریع جاوا اسکریپت</title><link>http://zebardast.ir/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b3%d8%b1%db%8c%d8%b9-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/</link> <comments>http://zebardast.ir/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b3%d8%b1%db%8c%d8%b9-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/#comments</comments> <pubDate>Thu, 19 Jan 2012 14:15:56 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[جاوا اسکریپت]]></category> <category><![CDATA[آموزش سریع]]></category> <category><![CDATA[برنامه نویسی]]></category> <category><![CDATA[راهنما]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1700</guid> <description><![CDATA[— JavaScript سلام، امروزه با توجه به استفاده گسترده از زبان جاوا اسکریپت (JavaScript)، دانستن آن برای هر توسعه دهنده وبی لازم است. این مقاله در یک نگاه و به طور خلاصه زبان جاوا اسکریپت و مفاهیم وی را معرفی کرده و در ادامه نحوه نگارش (Syntax) کدهای آن را آموزش می دهد. همچنین برای [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d8%ad%d8%b0%d9%81-%da%a9%d9%88%da%a9%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/' rel='bookmark' title='حذف کوکی در جاوا اسکریپت'>حذف کوکی در جاوا اسکریپت</a></li><li><a href='http://zebardast.ir/%d9%85%d9%82%d8%af%d9%85%d9%87-%d8%a7%db%8c-%d8%a8%d8%b1%d8%a7%db%8c-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/' rel='bookmark' title='مقدمه ای برای جاوا اسکریپت'>مقدمه ای برای جاوا اسکریپت</a></li><li><a href='http://zebardast.ir/querystring-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/' rel='bookmark' title='QueryString در جاوا اسکریپت'>QueryString در جاوا اسکریپت</a></li></ol>]]></description> <content:encoded><![CDATA[<div class="autocap alignleft" style="width: 200px;"><div><img src="http://zebardast.ir/wp-content/uploads/2012/01/JavaScript.jpg" alt="" title="JavaScript" width="200" class=" size-full wp-image-1826" /><p class="autocap-text"><span class="hide">— </span>JavaScript</p></div></div><p>سلام،</p><p>امروزه با توجه به استفاده گسترده از زبان جاوا اسکریپت (<a href="http://en.wikipedia.org/wiki/JavaScript" title="JavaScript" target="_blank">JavaScript</a>)، دانستن آن برای هر توسعه دهنده وبی لازم است. این مقاله در یک نگاه و به طور خلاصه زبان جاوا اسکریپت و مفاهیم وی را معرفی کرده و در ادامه نحوه نگارش (Syntax) کدهای آن را آموزش می دهد. همچنین برای درک بیشتر دستورات جاوا اسکریپت نمونه کدهایی در بین بخش‌های مختلف ارائه شده است.</p><h3>مقدمه</h3><p>جاوااسکریپت زبانی است که توسط NetScape تولید شده است. هدف از این زبان پویانمایی اشیا داخل صفحات HTML می باشد. <a href="/tag/%D8%AC%D8%A7%D9%88%D8%A7-%D8%A7%D8%B3%DA%A9%D8%B1%DB%8C%D9%BE%D8%AA/" title="جاوا اسکریپت" target="_blank">جاوا اسکریپت</a> کاملا با <a href="/tag/جاوا/" title="جاوا" target="_blank">زبان برنامه نویسی جاوا</a> فرق دارد. اگر چه ساختار این زبان به سی پلاس پلاس و جاوا شباهت دارد؛ که این امر برای سهولت یادگیری در نظر گرفته شده است. از همینرو دستورهای متداول مانند if, for, try..catch و &#8230; در این زبان هم یافت می‌گردند.<br /> کاربرد گسترده این زبان در سایتها و صفحات اینترنی می‌باشد و به کمک این زبان می‌توان به اشیاء داخل صفحات HTML دسترسی پیدا کرد و آنها را تغییر داد. به همین علت برای پویا نمایی در سمت کاربر، از این زبان استفاده می‌شود.</p><h3>نحوه نگارش مستقیم کدهای جاوا اسکریپت در HTML</h3><p>کدهای جاوا اسکریپت در صفحات HTML داخل تگ script قرار می گیرند. از خصیصه type برای مشخص کردن زبان اسکریپت نوشه شده استفاه می شود. <code>&lt;script type=&quot;text/javascript&quot;&gt;</code> محل شروع کدهای جاوا اسکرپیت و <code>&lt;/script&gt;</code> محل پایان کدهای جاوا اسکریپت را مشخص می کنند. مانند:</p><pre class="brush: xml; title: ; notranslate">
&lt;html&gt;
&lt;body&gt;
&lt;script type=&quot;text/javascript&quot;&gt;
document.write(&quot;Hello World!&quot;);
&lt;/script&gt;
&lt;/body&gt;
&lt;/html&gt;
</pre><p>خروجی کد بالا نوشته‌ی !Hello World می باشد.</p><h3>اسکریپت خارجی</h3><p>گاهی اوقات شما نیاز به اجرای یک کد جاوا اسکریپت در صفحات مختلف (بدون نگارش در تک تک صفحات) دارید. و یا کد شما بسیار طولانی است و هنگام کد نویسی در صفحه html شما را دچار مشکل می کند. در این صورت با استفاده از اسکریپت خارجی مشکل شما حل می شود. برای نگارش اسکریپت خارجی ابتدا یک فایل با فرمت js. ایجاد کنید. می توانید پسوند یک فایل txt را به js. تغییر دهید. سپس این فایل را توسط یک ویرایشگر متن مانند Notepad باز کنید. کدهای جاوا اسکریپت خود را بدون تگ <code>&lt;script&gt;</code> در آن قرار دهید و سپس فایل را ذخیره کنید (با پسوند js.)<br /> برای فراخوانی اسکریپت خارجی از خصیصه src تگ <code>&lt;script&gt;</code> استفاده کنید. مانند زیر که xxx.js آدرس فایل جاوا اسکریپت است:</p><pre class="brush: xml; title: ; notranslate">&lt;html&gt;
&lt;head&gt;
&lt;script type=&quot;text/javascript&quot;&gt;
&lt;script src=&quot;xxx.js&quot;&gt;&lt;/script&gt;
&lt;/script&gt;
&lt;/head&gt;
&lt;body&gt;
&lt;/body&gt;
&lt;/html&gt;
</pre><h3>سمی‌کالن <code>(;)</code>، فضاهای سفید و حساس به حروف (Case Sensitive)</h3><p>در جاوا اسکریپت دستورات اجرایی با سمی‌کالن (Semicolon) یا همان ; از هم جدا می شوند. با وجود اینکه استفاده از سمی‌کولن، در صورتی که دستورات در خطوط جداگانه نوشته شده باشند، اختیاریست، نوشتن آن بسیار توصیه می شود. بد نیست مطلب «<a href="http://zebardast.ir/معاهده%E2%80%8Cهای-کد-نویسی-coding-conventions/" title="معاهده‌های کدنویسی" target="_blank">معاهده‌های کدنویسی</a>» را مطالعه کنید.<br /> فضاها سفید در جاوا اسکرپیت مانند اغلب زبان‌های برنامه نویسی هنگام اجرا در نظر گرفته نمی شوند. مگر اینکه مقدار یک متغیر رشته ای (String) باشند.<br /> زبان جاوا اسکریپت به کوچکی و بزرگی حروف حساس می باشد. به عنوان مثال bgColor با bgcolor برای نیست.</p><h3>توضیحات (Comments)</h3><p>توضیحات می توانند به صورت تک خطی و یا چند خطی باشند. مانند:</p><pre class="brush: jscript; title: ; notranslate">
// این یک توضیح یک خطی است!

/*
این یک توضیح
چند خطی است.
*/
</pre><h3>متغیرها (Variables)</h3><p>برای تعریف متغیر کافیست نام دلخواه خود را بنویسید. استفاده از کلمه var قبل از نام متغیر اختیاری است، مگر در موارد زیر:</p><ul><li> زمانی که نام یک متغیر محلی در داخل یک تابع با نام یک متغیر سراسری (Global) یکی باشد، متغیر محلی باید با var تعریف شود. در این مواقع شما در داخل تابع خود دسترسی به متغیر سراسری ندارید. هم چنین متغیرهای محلی فقط در داخل خود تابع قابل دستیابی می باشند.</li><li> در توابع بازگشتی استفاده از var الزامیست.</li></ul><h4>نمونه تعریف متغیر در جاوا اسکریپت</h4><pre class="brush: jscript; title: ; notranslate">
x = 42
var x = 42
</pre><h3>انواع داده‌ها در جاوا اسکریپت</h3><p>شما می تواند داده‌هایی از نوع زیر را در جاوا اسکریپ تعریف کنید:</p><ul><li> شی (Object)</li><li> تابع (Function)</li><li> رشته (String)</li><li> عدد (Number)</li><li> نوع داده منطقی (Boolean)</li></ul><p>در صورتی که متغییری تعریف نشده باشد، نوع آن متغیر undefined است. برای دستیابی به نوع یک متغیر می توانید از تابع typeof استفاده کنید. در زیر نمونه تعریف متغیرها و استفاده از تابع typeof را مشاهده می کنید:</p><pre class="brush: jscript; title: ; notranslate">
var aDate = new Date()
var aPowerFunc = new Function(&quot;x&quot;, &quot;return x * x&quot;)
var aString = &quot;I am a string&quot;
var aNumber = 42
var aBoolean = true

alert(typeof aPowerFunc); // typeof aPowerFunc is object
alert(typeof aDate); // typeof aDate is object
alert(typeof aString); // typeof aString is string
alert(typeof aNumber); // typeof aNumber is number
alert(typeof aBoolean); // typeof aBoolean is boolean
alert(typeof nonExistVar); // typeof nonExistVar is undefined
alert(typeof Date); // typeof Date is function. predefined object Date
</pre><h3>آرایه ها (Arrays)</h3><p>روش‌های مختلفی برای تعریف آرایه در جاوا اسکریپت وجود دارد. در زیر نمونه‌هایی از تعریف آرایه‌ها ارائه شده است:</p><pre class="brush: jscript; title: ; notranslate">
beans = [&quot;Java beans&quot;,&quot;Coffee beans&quot;,&quot;Cacao beans&quot;];
myCars = new Array(&quot;Jaguar&quot;, &quot;Mercedes&quot;, &quot;Rolls Royce&quot;);
noOfEntries = myCars.length; // طول آرایه
myCD = new Array(42) // تعریف آرایه ای به نام myCD با 42 عضو
myCD[0] = &quot;Queen&quot; //اولین عنصر آرایه
myCD[1] = &quot;Carlos Santana&quot;
myCD[2] = &quot;Mozart&quot;
myCD[3] = &quot;Chopin&quot;
...
myCD[41] = &quot;Shubidua&quot; //آخرین عنصر آرایه
// تعریف آرایه با کلیدهای مشخص - Associative Array ویا همان Property Maps
assoarr = {color1: &quot;green&quot;, color2: &quot;yellow&quot;, color3: &quot;white&quot;};
</pre><h3>اشیا (Objects)</h3><p>تعریف یک شی مانند تعریف یک تابع می باشد. مانند:</p><pre class="brush: jscript; title: ; notranslate">
function objDef(name) {
this.objvar = name
}
// creation of an instance of the above defined object &quot;class&quot; myObj = new objDef(&quot;Saeid&quot;)
</pre><h3>متدها و خصوصیات (Methods, Properties)</h3><p>متد همان تابع تعریف شده در یک شی و خصیصه، مقادیر متغیرهای آن می‌باشد. مانند:</p><pre class="brush: jscript; title: ; notranslate">
//Property
//objectName.propertyName = value
//Method
//objectName.methodName = function

function calcArea(radius) {
return(radius * radius * Math.PI);
}

function circle(color, radius) {
this.fillColor = color;
this.area = calcArea(radius);
}

var myCircle = new circle('green', 2);
alert(myCircle.fillColor);
alert(myCircle.area);
</pre><h3>عملگرها در جاوا اسکریپت</h3><p>در زیر عملگرها بر اساس نوع عملیات و داده مورد استفاده دسته‌بندی شده‌اند.</p><table cellspacing="0" cellpadding="0" class="info"><caption>انواع عملگرها برای اعداد</caption><thead><tr><th width='100'>عملگر</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr">+</td><td>جمع</td></tr><tr><td class="ltr">-</td><td>تفریق</td></tr><tr><td class="ltr">++</td><td>افزایش مقدار متغییر به اندازه یک واحد</td></tr><tr><td class="ltr">&#8211;</td><td>کاهش مقدار متغییر به اندازه یک واحد</td></tr><tr><td class="ltr">*</td><td>ضرب</td></tr><tr><td class="ltr">/</td><td>تقسیم</td></tr><tr><td class="ltr">%</td><td>باقیمانده</td></tr></tbody></table><table cellspacing="0" cellpadding="0" class="info"><caption>انواع عملگرها برای رشته‌ها</caption><thead><tr><th width='100'>عملگر</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr">+</td><td>الحاق دو یا چند رشته</td></tr><tr><td class="ltr">+=</td><td>الحاق محتوای یک رشته با یک یا چند رشته و اختصاص دادن مقدار به رشته اول</td></tr></tbody></table><table cellspacing="0" cellpadding="0" class="info"><caption>انواع عملگرهای منظقی</caption><thead><tr><th width='100'>عملگر</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr">&#038;&#038;</td><td>و (AND)</td></tr><tr><td class="ltr">||</td><td>یا (OR)</td></tr><tr><td class="ltr">!</td><td>خِلاف (NOT)</td></tr><tr><td class="ltr">==</td><td>مساوی با (equal)</td></tr><tr><td class="ltr">!=</td><td>نامساوی با (not equal)</td></tr><tr><td class="ltr">===</td><td>دقیقا مساوی با (از نظر مقدار و نوع داده)</td></tr><tr><td class="ltr">!==</td><td>نامساوی با (از نظر ارزش) <strong>ویا</strong> نامساوی (از نظر نوع)</td></tr><tr><td class="ltr">&gt;</td><td>بزرگتر از</td></tr><tr><td class="ltr">&gt;=</td><td>بزرگتر از ویا مساوی با (بزرگترمساوی)</td></tr><tr><td class="ltr">&lt;</td><td>کوچکتر</td></tr><tr><td class="ltr">&lt;=</td><td>کوچکتر از ویا مساوی با (کوچکتر مساوی)</td></tr></tbody></table><table cellspacing="0" cellpadding="0" class="info"><caption>انواع عملگرها برای تخصیص</caption><thead><tr><th width='100'>عملگر</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr">=</td><td>اختصاص دادن یک مقدار به متغیر</td></tr><tr><td class="ltr">+=</td><td>الحاق محتوای متغیر سمت چپ عملگر با یک متغیر و اختصاص دادن مقدار به متغیر سمت چپ</td></tr><tr><td class="ltr">-=</td><td>تفریق یک متغیر از متغیر سمت چپ عملگر و اختصاص دادن مقدار بدست آمده به متغیر سمت چپ</td></tr><tr><td class="ltr">*=</td><td>ضرب یک متغیر در متغیر سمت چپ عملگر و اختصاص دادن مقدار بدست آمده به متغیر سمت چپ</td></tr><tr><td class="ltr">/=</td><td>تقسیم متغیر سمت چپ عملگر و اختصاص دادن مقدار بدست آمده به متغیر سمت چپ</td></tr><tr><td class="ltr">%=</td><td>تقسیم متغیر سمت چپ عملگر و اختصاص دادن باقیمانده تقسیم به متغیر سمت چپ</td></tr></tbody></table><table cellspacing="0" cellpadding="0" class="info"><caption>سایر عملگرها</caption><thead><tr><th width='100'>عملگر</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr">new</td><td>ایجاد یک شی</td></tr><tr><td class="ltr">delete</td><td>حذف یک شی</td></tr><tr><td class="ltr">this</td><td>اشاره به شی جاری</td></tr><tr><td class="ltr">typeof</td><td>دستیابی به نوع متغیر عملوند</td></tr><tr><td class="ltr">void</td><td>ارزیابی یک عبارت بودن بازیابی مقدار آن</td></tr></tbody></table><h3>عبارت‌های شرطی (Conditional Statements)</h3><p>در زیر نحوه نگارش عبارت‌های شرطی با if و switch ارائه شده است.</p><h4>عبارت شرطی با if</h4><pre class="brush: jscript; title: ; notranslate">
// if ساده
if (condition) {
 statements
}

// if همراه با else
if (condition) { statements
} else {
statements
}

// if خلاصه یک خطی
condition ?  expr1 :  expr2
</pre><h4>عبارت شرطی با switch</h4><pre class="brush: jscript; title: ; notranslate">
switch (expression){ case label:
statement;
  break;
 case label2:
statement;
  break;
 default :  statement;
}
</pre><h3>حلقه ها (Loops)</h3><p>در جاوا اسکریپت امکان نوشتن حلقه ها به چهار صورت امکان پذیر است.</p><h4>حلقه for</h4><pre class="brush: jscript; title: ; notranslate">
for(var i=0; i &lt; array.length; i++){
 ...
}
</pre><h4>حلقه do &#8230; while</h4><pre class="brush: jscript; title: ; notranslate">
var i=0; do {
i+=1;
} while (i &lt; 5)
</pre><h4>حلقه while</h4><pre class="brush: jscript; title: ; notranslate">
n=8
while( n &gt; 0) {
n--
}
</pre><h4>حلقه while</h4><p>این حلقه بر روی خصوصیات یک شی اعمالی را انجام می دهد:</p><pre class="brush: jscript; title: ; notranslate">
student1 = new Student(&quot;Hans Christian&quot;, &quot;Andersen&quot;, 1805); for (props in student1) {
  document.write(student1.props)
}
</pre><h4>دستور break و continue</h4><p>مانند سایر زبان‌های برنامه‌نویسی دستور break حلقه را قطع کرده و برنامه را به بعد از حلقه منتقل می‌کند. دستور continue نیز مانند break حلقه جاری را قطع می‌کند و در ادامه دور بعدی حلقه را اجرا می کند. مانند:</p><pre class="brush: jscript; title: ; notranslate">
while(i &gt; 0){ if(a[i]==&quot;Orange&quot;)
break; i--;
}
while(i &gt; 0){
 if(a[i]!=&quot;Orange&quot;)
  continue;
oranges++;
}
</pre><h3>معرفی بعضی از اشیا موجود در جاوا اسکریپت</h3><p>مهمترین آبجکت‌های جاوا اسکریپت عبارتند از:</p><pre class="brush: jscript; title: ; notranslate">
Date
Array
Boolean
Function
Math
Number
RegExp
String
</pre><p>در ادامه تعدادی از این اشیا بررسی شده اند.</p><h4>شی Date</h4><table cellspacing="0" cellpadding="0" class="info"><caption>برخی از متدهای شی Date</caption><thead><tr><th width='100'>متد</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr"><code>getDate()</code></td><td>بازیابی روز ماه جاری (۱-۳۱)</td></tr><tr><td class="ltr"><code>getDay()</code></td><td>بازیابی شماره روز هفته جاری (۰-۶)</td></tr><tr><td class="ltr"><code>getYear()</code></td><td>سال جاری دو رقمی بین ۰ تا ۹۹ برای سالهای قبل از ۱۹۹۹ و چهار رقمی برای سال‌های بعد از آن</td></tr><tr><td class="ltr"><code>getFullYear()</code></td><td>سال جاری چهار رقمی</td></tr><tr><td class="ltr"><code>getHours()</code></td><td>ساعت (۰-۲۳)</td></tr><tr><td class="ltr"><code>getMonth()</code></td><td>ماه (۰-۱۱) &#8211; این شماره از ماه جاری یک ماه کمتر است.</td></tr><tr><td class="ltr"><code>getSeconds()</code></td><td>ثانیه جاری (۰-۵۹)</td></tr><tr><td class="ltr"><code>getTime()</code></td><td>تعداد میلی‌ثانی‌های گذشته از تاریخ ۱ ژانویه ۱۹۷۰</td></tr><tr><td class="ltr"><code>setDate(),<br /> setHours(),<br /> . . .</code></td><td>مقداردهی به تاریخ و زمان مورد نظر</td></tr><tr><td class="ltr"><code>parse()</code></td><td>دستیابی به زمان طی شده از ۱ ژانویه ۱۹۷۰ تا زمان مورد نظر در واحد میلی‌ثانیه</td></tr><tr><td class="ltr"><code>toString()</code></td><td>تبدیل تاریخ به رشته</td></tr></tbody></table><p>برای استفاده از شی Date می توانید مانند زیر عمل کنید:</p><pre class="brush: jscript; title: ; notranslate">
now = new Date // تاریخ جاری
nowDay = now.getDay() // (0-6)
nowHour = now.getHour() // (0-23)
</pre><h4>شی Boolean</h4><p>استفاده از شی Boolean بسیار ساده می باشد. در زیر نمونه تعریف آن آمده است:</p><pre class="brush: jscript; title: ; notranslate">
x = true; // مقدار منطقی true
y = false; // مقدار منطقی false
z = new Boolean(false); // مقدار این شی false است.
z2 = new Boolean(&quot;false&quot;); // مقدار ای شی true است! دقت کنید که هر رشته ای که به شی Boolean پاس شود مقدار ای شی را true می کند.
z3 = new Boolean(true); // مقدار این شی true است.
</pre><h4>شی Math</h4><p>همانطور که از اسم این شی مشخص است، کاربرد آن بیشتر در محاسبات و عبارت‌های ریاضی است.</p><table cellspacing="0" cellpadding="0" class="info"><caption>برخی از متدهای شی Math</caption><thead><tr><th width='100'>متد یا عبارت</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr"><code>abs</code></td><td>قدرمطلق</td></tr><tr><td class="ltr"> <code>sin, cos, tan</code><br /> <code>acos, asin, atan</code></td><td>توابع مثلثاتی</td></tr><tr><td class="ltr"><code>min, max</code></td><td>بدست آورن کمترین و بیشترین مقدار</td></tr><tr><td class="ltr"><code>round</code></td><td>گردکردن مقدار</td></tr><tr><td class="ltr"><code>sqrt</code></td><td>بدست آوردن جذر یک عدد</td></tr><tr><td class="ltr"><code>pow</code></td><td>توان. اولین مقدار، پایه توان و دومین مقدار نمای آن می باشد. به عنوان مثال <code>Math.pow(x,y)</code> برابر است با <code>x<sup>y</sup></code></td></tr><tr><td class="ltr"><code>random</code></td><td>ایجاد یک عدد رندوم بین صفر و یک.</td></tr><tr><td class="ltr"><code>Math.E</code></td><td>مقدار ثابت عدد e (فرمول اولر یا اویلر) حدود ۲,۷۱۸</td></tr><tr><td class="ltr"><code>Math.PI</code></td><td>مقدار ثابت عدد پی. حدود ۳,۱۴۱۵۹</td></tr></tbody></table><p>نمونه استفاده از آبجکت Math:</p><pre class="brush: jscript; title: ; notranslate">
a = Math.PI * r*r; with(Math){
a = PI * r*r;
x = sin(y);
}
</pre><h4>شی String</h4><table cellspacing="0" cellpadding="0" class="info"><caption>برخی از متدهای شی String</caption><thead><tr><th width='100'>متد</th><th>توضیحات</th></tr></thead><tbody><tr><td class="ltr"><code>bold</code></td><td>مانند تگ &lt;bold&gt; رشته را درشت‌تر می‌کند.</td></tr><tr><td class="ltr"><code>italics</code></td><td>مانند تگ &lt;i&gt; عمل می کند.</td></tr><tr><td class="ltr"><code>concat</code></td><td>الحاق ۲ یا چند رشته</td></tr><tr><td class="ltr"><code>charAt</code></td><td>دستیابی به کاراکتر از طریق ایندکس (اندیس) آن در رشته</td></tr><tr><td class="ltr"><code>fontcolor</code></td><td>مانند تگ &lt;font&gt; به صورت &lt;font color=color&gt; عمل می‌کند.</td></tr><tr><td class="ltr"><code>fontsize</code></td><td>مانند تگ &lt;font&gt; به صورت &lt;font size=size&gt; عمل می‌کند.</td></tr><tr><td class="ltr"><code>indexOf</code></td><td>پیدا کردن اولین محل یافت شده از یک رشته در رشته دیگر. در صورتی که این جستجو نتیجه‌ای در بر نداشته باشد، مقدار <code>-۱</code> بازگردانده خواهد شد.</td></tr><tr><td class="ltr"><code>lastIndexOf</code></td><td>مانند indexOf با این تفاوت که آخرین محل یافت شده در جستجو را نشان می‌دهد.</td></tr><tr><td class="ltr"><code>length</code></td><td>طول رشته را نشان می‌دهد.</td></tr><tr><td class="ltr"><code>link</code></td><td>برای ایجاد لینک مانند تگ &lt;a&gt;</td></tr><tr><td class="ltr"><code>big</code></td><td>مانند تگ &lt;big&gt;</td></tr><tr><td class="ltr"><code>small</code></td><td>مانند تگ &lt;small&gt;</td></tr><tr><td class="ltr"><code>strike</code></td><td>مانند تگ &lt;strike&gt;</td></tr><tr><td class="ltr"><code>sub</code></td><td>مانند تگ &lt;sub&gt;</td></tr><tr><td class="ltr"><code>substring</code></td><td>دستیابی به یک زیررشته از رشته مورد نظر.</td></tr><tr><td class="ltr"><code>toLowerCase</code></td><td>تبدیل رشته به حروف کوچک</td></tr><tr><td class="ltr"><code>toUpperCase</code></td><td>تبدیل رشته به حروف بزرگ</td></tr><tr><td class="ltr"><code>replace</code></td><td>برای جایگزینه یک رشته در رشته دیگر کاربرد دارد.</td></tr><tr><td class="ltr"><code>split</code></td><td>برای جداکردن رشته بر اساس یک الگو (جداکننده) کاربرد دارد.</td></tr></tbody></table><p>مثال‌هایی از استفاده شی String و متدهای آن در زیر ارائه شده است:</p><pre class="brush: jscript; title: ; notranslate">
var message = &quot;Simple String&quot;;
message[0]; // مقدار &quot;S&quot; باز می‌گرداند.
document.write(message.bold()); // محتوای متغییر را به صورت درشت چاپ می‌کند.
message.charAt(0); // همان message[0] می‌باشد.
message.concat(&quot; enhanced&quot;); // مقدار &quot;Simple String enhanced&quot; را باز می‌گرداند.
message.length; // طول عبارت که همان عدد ۱۳ می باشد را باز می‌گرداند
message.indexOf(&quot;Simple&quot;); // عدد ۰ را باز می‌گرداند.
message.lastIndexOf(&quot;String&quot;); // عدد ۷ را باز می‌گرداند.
message.substring(2,5); // رشته &quot;mple&quot; را باز می‌گرداند.
document.write(message.replace(&quot;Simple&quot;, &quot;Complex&quot;)); // مقدار &quot;Complex String&quot; را باز می‌گرداند.
</pre><h3>رویدادها (Events)</h3><p>منظور از رویداد، انتفاقی است که در سمت کاربر و براساس فعالیت‌های آن رخ می‌دهد. در زیر تعدادی از رویدادها مهم ارائه شده‌اند. دقت نمایید که فراخوانی آن‌ها در تگ‌های خاصی امکان پذیر است. به عنوان مثال رویداد onSubmit در تگ &lt;form&gt; فراخوانده می‌شود.</p><table cellspacing="0" cellpadding="0" class="info"><caption>تعدادی از رویدادهای مهم در جاوا اسکریپت</caption><thead><tr><th width='100'>رویداد</th><th>زمان رخ دادن و فراخوانی</th></tr></thead><tbody><tr><td class="ltr"><code>onSubmit</code></td><td>هنگام ثبت شدن فرم</td></tr><tr><td class="ltr"><code>onReset</code></td><td>هنگام زدن دکمه reset فرم</td></tr><tr><td class="ltr"><code>onChange</code></td><td>هنگام تغییر یک مقدار</td></tr><tr><td class="ltr"><code>onSelect</code></td><td>هنگام انتخاب یک متن در تگ &lt;input&gt; یا &lt;textarea&gt;</td></tr><tr><td class="ltr"><code>onBlur</code></td><td>هنگام خارج شدن از فوکوس یک فیلد</td></tr><tr><td class="ltr"><code>onFocus</code></td><td>هنگام فوکوس (انتخاب) یک فیلد</td></tr><tr><td class="ltr"><code>onKeydown</code></td><td>هنگام فشردن یک کلید به پایین</td></tr><tr><td class="ltr"><code>onKeyup</code></td><td>بعد از فشردن و رها کردن یک کلید</td></tr><tr><td class="ltr"><code>onKeypress</code></td><td>هنگام فشردن یک کلید (مجموع onKeydown و onKeyup)</td></tr><tr><td class="ltr"><code>onMouseover</code></td><td>زمانی که نشانگر ماوس بر روی منطقه تگ مورد نظر می رود.</td></tr><tr><td class="ltr"><code>onMouseout</code></td><td>هنگامی که نشانگر ماوس از منطقه تگ مورد نظر خارج می شود.</td></tr><tr><td class="ltr"><code>onMousemove</code></td><td>هنگام حرکت دادن نشانگر ماوس در یک منطقه</td></tr><tr><td class="ltr"><code>onClick</code></td><td>هنگام کلیک کردن</td></tr><tr><td class="ltr"><code>onDblclick</code></td><td>هنگام دابل کلیک کردن</td></tr><tr><td class="ltr"><code>onLoad</code></td><td>هنگام بارگزاری صفحه</td></tr><tr><td class="ltr"><code>onUnload</code></td><td>هنگام بستن صفحه مورد نظر</td></tr><tr><td class="ltr"><code>onResize</code></td><td>هنگام تغییر دادن سایز صفحه (پنچره) مورد نظر</td></tr><tr><td class="ltr"><code>onError</code></td><td>هنگام رخ دادن یک خطا جاوا اسکریپتی</td></tr></tbody></table><h3>پی‌نوشت</h3><p>همانطور که در ابتدای مقاله گفته شد این مقاله فقط به طور کلی جاوا اسکریپت و دستورات آن را معرفی کرده است. در صورتی که علاقمند به آشنایی بیشتر و دقیق‌تر این زبان هستید، می توانید به منابع معرفی شده در انتهای همین مطلب مراجعه نمایید.</p><h3>منابع</h3><ul><li><a href="http://fa.wikipedia.org/wiki/%D8%AC%D8%A7%D9%88%D8%A7%D8%A7%D8%B3%DA%A9%D8%B1%DB%8C%D9%BE%D8%AA" title="جاوا اسکریپت" target="_blank">جاوا اسکریپت</a> (ویکی پدیای فارسی)</li><li class='ltr'><a href="http://www.w3schools.com/jsref/default.asp" title="JavaScript and HTML DOM Reference" target="_blank">JavaScript and HTML DOM Reference</a></li><li class='ltr'><a href="http://javascript.infogami.com/Javascript_in_Ten_Minutes" title="Javascript in Ten Minutes" target="_blank">Javascript in Ten Minutes</a></li><li class='ltr'><a href="http://sage.math.washington.edu/home/agc/lit/javascript/javascriptcheatsheet.pdf" title="JavaScript cheat sheet" target="_blank">JavaScript cheat sheet</a></li></ul><p>شاد و پیروز باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b1%25d8%25a7%25d9%2587%25d9%2586%25d9%2585%25d8%25a7%25db%258c-%25d8%25b3%25d8%25b1%25db%258c%25d8%25b9-%25d8%25ac%25d8%25a7%25d9%2588%25d8%25a7-%25d8%25a7%25d8%25b3%25da%25a9%25d8%25b1%25db%258c%25d9%25be%25d8%25aa%2F&amp;linkname=%D8%B1%D8%A7%D9%87%D9%86%D9%85%D8%A7%DB%8C%20%D8%B3%D8%B1%DB%8C%D8%B9%20%D8%AC%D8%A7%D9%88%D8%A7%20%D8%A7%D8%B3%DA%A9%D8%B1%DB%8C%D9%BE%D8%AA" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b1%25d8%25a7%25d9%2587%25d9%2586%25d9%2585%25d8%25a7%25db%258c-%25d8%25b3%25d8%25b1%25db%258c%25d8%25b9-%25d8%25ac%25d8%25a7%25d9%2588%25d8%25a7-%25d8%25a7%25d8%25b3%25da%25a9%25d8%25b1%25db%258c%25d9%25be%25d8%25aa%2F&amp;linkname=%D8%B1%D8%A7%D9%87%D9%86%D9%85%D8%A7%DB%8C%20%D8%B3%D8%B1%DB%8C%D8%B9%20%D8%AC%D8%A7%D9%88%D8%A7%20%D8%A7%D8%B3%DA%A9%D8%B1%DB%8C%D9%BE%D8%AA" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b1%25d8%25a7%25d9%2587%25d9%2586%25d9%2585%25d8%25a7%25db%258c-%25d8%25b3%25d8%25b1%25db%258c%25d8%25b9-%25d8%25ac%25d8%25a7%25d9%2588%25d8%25a7-%25d8%25a7%25d8%25b3%25da%25a9%25d8%25b1%25db%258c%25d9%25be%25d8%25aa%2F&amp;linkname=%D8%B1%D8%A7%D9%87%D9%86%D9%85%D8%A7%DB%8C%20%D8%B3%D8%B1%DB%8C%D8%B9%20%D8%AC%D8%A7%D9%88%D8%A7%20%D8%A7%D8%B3%DA%A9%D8%B1%DB%8C%D9%BE%D8%AA" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b1%25d8%25a7%25d9%2587%25d9%2586%25d9%2585%25d8%25a7%25db%258c-%25d8%25b3%25d8%25b1%25db%258c%25d8%25b9-%25d8%25ac%25d8%25a7%25d9%2588%25d8%25a7-%25d8%25a7%25d8%25b3%25da%25a9%25d8%25b1%25db%258c%25d9%25be%25d8%25aa%2F&amp;linkname=%D8%B1%D8%A7%D9%87%D9%86%D9%85%D8%A7%DB%8C%20%D8%B3%D8%B1%DB%8C%D8%B9%20%D8%AC%D8%A7%D9%88%D8%A7%20%D8%A7%D8%B3%DA%A9%D8%B1%DB%8C%D9%BE%D8%AA" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d8%25b1%25d8%25a7%25d9%2587%25d9%2586%25d9%2585%25d8%25a7%25db%258c-%25d8%25b3%25d8%25b1%25db%258c%25d8%25b9-%25d8%25ac%25d8%25a7%25d9%2588%25d8%25a7-%25d8%25a7%25d8%25b3%25da%25a9%25d8%25b1%25db%258c%25d9%25be%25d8%25aa%2F&amp;title=%D8%B1%D8%A7%D9%87%D9%86%D9%85%D8%A7%DB%8C%20%D8%B3%D8%B1%DB%8C%D8%B9%20%D8%AC%D8%A7%D9%88%D8%A7%20%D8%A7%D8%B3%DA%A9%D8%B1%DB%8C%D9%BE%D8%AA" id="wpa2a_4">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d8%ad%d8%b0%d9%81-%da%a9%d9%88%da%a9%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/' rel='bookmark' title='حذف کوکی در جاوا اسکریپت'>حذف کوکی در جاوا اسکریپت</a></li><li><a href='http://zebardast.ir/%d9%85%d9%82%d8%af%d9%85%d9%87-%d8%a7%db%8c-%d8%a8%d8%b1%d8%a7%db%8c-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/' rel='bookmark' title='مقدمه ای برای جاوا اسکریپت'>مقدمه ای برای جاوا اسکریپت</a></li><li><a href='http://zebardast.ir/querystring-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/' rel='bookmark' title='QueryString در جاوا اسکریپت'>QueryString در جاوا اسکریپت</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b3%d8%b1%db%8c%d8%b9-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/feed/</wfw:commentRss> <slash:comments>6</slash:comments> </item> <item><title>معاهده‌های کدنویسی (Coding conventions)</title><link>http://zebardast.ir/%d9%85%d8%b9%d8%a7%d9%87%d8%af%d9%87%e2%80%8c%d9%87%d8%a7%db%8c-%da%a9%d8%af-%d9%86%d9%88%db%8c%d8%b3%db%8c-coding-conventions/</link> <comments>http://zebardast.ir/%d9%85%d8%b9%d8%a7%d9%87%d8%af%d9%87%e2%80%8c%d9%87%d8%a7%db%8c-%da%a9%d8%af-%d9%86%d9%88%db%8c%d8%b3%db%8c-coding-conventions/#comments</comments> <pubDate>Sat, 07 Jan 2012 15:09:39 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[برنامه نویسی]]></category> <category><![CDATA[جاوا]]></category> <category><![CDATA[Java]]></category> <category><![CDATA[نرم‌افزار]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1698</guid> <description><![CDATA[— برنامه نویس کامپیوتر سلام، معاهده‌های کدنویسی (Coding conventions) به مجموعه استانداردها و روش‌های کدنویسی یک زبان برنامه نویسی گفته می شود که معمولا توسط توسعه دهنده آن زبان معرفی می شود. این مقاله به معرفی مهم ترین معاهده‌های برنامه نویسی می پردازد. در انتها فهرستی از معاهده‌های کدنویسی مهم‌ترین زبان‌های برنامه‌نویسی ارائه شده است. [...] مطلب مرتبطی یافت نشد.]]></description> <content:encoded><![CDATA[<div class="autocap alignleft" style="width: 300px;"><div><a href="http://zebardast.ir/wp-content/uploads/2012/01/برنامه-نویس-کامپیوتر.jpg"><img src="http://zebardast.ir/wp-content/uploads/2012/01/برنامه-نویس-کامپیوتر-300x199.jpg" alt="" title="برنامه نویس کامپیوتر" width="300" height="199" class=" size-medium wp-image-1735" /></a><p class="autocap-text"><span class="hide">— </span>برنامه نویس کامپیوتر</p></div></div><p>سلام،</p><p><abbr title="کنوانسیون - Convention">معاهده‌</abbr>های کدنویسی (Coding conventions) به مجموعه استانداردها و روش‌های کدنویسی یک زبان برنامه نویسی گفته می شود که معمولا توسط توسعه دهنده آن زبان معرفی می شود. این مقاله به معرفی مهم ترین معاهده‌های برنامه نویسی می پردازد. در انتها فهرستی از معاهده‌های کدنویسی مهم‌ترین زبان‌های برنامه‌نویسی ارائه شده است.</p><h3>مقدمه</h3><p>به مجموعه استانداردها و روش‌های کدنویسی توسط یک زبان برنامه نویسی، معاهده‌های کدنویسی این زبان گفته می‌شود. این معاهده‌ها دربرگیرنده راهنماهایی در زمینه ساختار فایل، فاصله‌ها، توضیحات، تعاریف، عبارات، فضاهای خالی، نامگذاری و&#8230; می باشند. معمولا توسعه دهنده یک زبان برنامه نویسی این معاهده‌ها را ارائه می کند. البته تیم‌ها، شرکت‌ها و سازمان‌ها نیز ممکن است استاندارد‌های خاص خود را به همراه این معاهده‌ها به برنامه نویسان خود ابلاغ نمایند.<br /> برنامه‌نویسان و توسعه دهندگان نرم‌افزارها استفاده از این استانداردها را بسیار توصیه می کنند. استفاده از معاهده‌ها علاوه بر افزایش خوانایی کدهای برنامه، نگهداری (Maintenance) نرم‌افزار را نیز آسان‌تر می کند. این نکته را در نظر داشته باشید که استفاده از معاهده‌ها اجباری نبوده و در صورت عدم استفاده از آن‌ها به خطای کامپایلر برخورد نمی‌نمایید.</p><h3>نگهداری نرم‌افزار</h3><p>کم‌کردن هزینه نگهداری نرم‌افزار (Software Maintenance) مهم‌ترین دلیل پیروی از معاهده‌های برنامه نویسی است. شرکت سان مایکروسیستمز در معرفی معاهده‌های کدنویسی زبان جاوا چهار عامل زیر را دلیل ارائه معاهده‌های کدنویسی معرفی کرده است:</p><ol><li> ۸۰٪ از هزینه طول عمر یک نرم‌افزار صرف تعمیر و نگهداری آن می شود.</li><li> معمولا برنامه‌نویس نرم‌افزار در طول عمر نرم‌افزار عوض شده و ثابت باقی نمی‌ماند.</li><li> معاهده‌های کدنویسی با افزایش خوانایی کدهای برنامه به مهندسان این امکان را می‌دهند که کد‌های جدید را سریع‌تر و کامل‌تر درک کنند.</li><li> در صورتی که شما کد منبع خود را به عنوان یک محصول عرضه می‌نمایید، باید از صحیح، مرتب و یکسان بود کد‌های خود در محصولات مختلف‌تان مطمئن باشید.</li></ol><h4>کیفیت</h4><p>در فرایند توسعه نرم‌افزار مرحله‌ای با عنوان ارزشیابی همتایان (Peer review) وجود دارد که در طی آن شخص انجام دهنده یک کار، تکلیف صورت گرفته را همراه با یک یا چند تن از همکاران خود ارزیابی می کند. هدف از این مرحله بررسی منظم محصول به منظور یافتن مشکلات احتمالی و رفع ایراد آن‌ها می‌باشد. نام انگلیسی این مرحله (Software peer review) است.<br /> Software peer review غالبا به بررسی کدها منبع می‌پردازد. در صورتی که کد منبع از معاهده‌های زبان مورد نظر پیروی کرده باشد، علاوه بر افزایش کیفیت کد منبع موجب می شود تا مشاهده، بررسی و رفع ایرادات برای تیم ارزشیابی بسیار آسان‌تر شود.<br /> با انجام صحیح ارزشیابی همتایان، بسیاری از مشکلات احتمالی حال و آینده رفع خواهد شد. به عنوان مثال در صورت مراجعه مجدد به کدمنبع در آینده فهمیدن و درک کدی که درست ارزشیابی شده و از معاهده‌ها پیروی کرده است راحت‌تر بوده و زمان کمتری را نیاز خواهد داشت.</p><h4>تغییر در ساختار کد (Refactoring)</h4><p>منظور از refactoring فعالیتی است که طی آن خوانایی کدمنبع افزایش یافته و ساختار وی بهبود می یابد. به طور کلی هر تغییری در کدمنبع که رفتار یک نرم‌افزار را تغییر ندهد می تواند به عنوان refactoring در نظر گرفته شود. برخی از این تغییرات عبارتند از: تغییر نام متغییرها، تغییر نام متدها و توابع، عوض کردن محل قرارگیری یک متد (یا کل کلاس) و شکستن یک متد یا تابع بزرگ به متدها یا توابع کوچک‌تر.<br /> refactoring در برنامه نویسی یک نرم‌افزار به صورت تیمی، در مراحل ابتدایی کدنویسی انجام می شود. هدف از این کار یکسان کردن استانداردها و ساختار کدهای نوشته شده توسط اعضای تیم است. انتظار می رود که بعد از این مرحله اعضای تیم بیشتر معاهده‌ها و استانداردها را فراگرفته و از آن‌ها پیروی نمایند.</p><h3>اتوماسیون وظایف (Task automation)</h3><p>معاهده‌های کدنویسی این امکان را فراهم می کنند تا فرایندهایی غیر از کامپایل و اجرای نرم‌افزارها را به آسانی انجام داد. از جمله مهم‌ترین این فرایندها می توان به ساخت و انتشار خودکار مستندات برنامه اشاره کرد. به عنوان مثال شما می توانید با نوشتن برچسب‌های author، version، param و&#8230; در توضیحات کدمنبع به صورت خودکار مستندات فنی نرم‌افزار خود را ایجاد کنید. به کد جاوای زیر توجه کنید:</p><pre class="brush: java; title: ; notranslate">
/**
 * Simple calculator operation.
 * @author &lt;a href=&quot;mailto:me@my.com&quot;&gt;Me&lt;/a&gt;
 * @version 1.0
 */
public interface Operation {
    /**
     * Perform a single calculation.
     * @param operand the operand to use for calculation.
     */
    public void calculate(double operand);

    /**
     * Get the current result.
     * @return the current result. If no calculations were
     *         performed the result is undefined.
     */
    public double getResult();
}
</pre><p>تصویر زیر خروجی HTML تولید شده با نرم‌افزار Javadoc را نشان می دهد:</p><div class="autocap alignnone" style="width: 580px;"><div><a href="http://zebardast.ir/wp-content/uploads/2012/01/javadoc.Operation.java_.png"><img src="http://zebardast.ir/wp-content/uploads/2012/01/javadoc.Operation.java_-1024x640.png" alt="" title="خروجی HTML تولید شده با نرم‌افزار Javadoc" width="580" height="362" class="alignnone size-large wp-image-1730" /></a><p class="autocap-text"><span class="hide">— </span>خروجی HTML تولید شده با نرم‌افزار Javadoc</p></div></div><h3>برخی از معاهده‌های کدنویسی مهمترین زبان‌های برنامه نویسی</h3><p>در زیر پیوندهایی به تعدادی از معاهده‌های کدنویسی ارائه شده است:</p><ul><li><a href="http://www.oracle.com/technetwork/java/codeconv-138413.html" title="معاهده‌های کدنویسی زبان جاوا" target="_blank">معاهده‌های کدنویسی زبان جاوا</a></li><li><a href="http://www.jetcafe.org/jim/c-style.html" title="استانداردهای کد نویسی در ANSI C" target="_blank">استانداردهای کدنویسی در ANSI C</a></li><li><a href="http://gcc.gnu.org/wiki/CppConventions" title="معاهده‌های کدنویسی C++ GCC">معاهده‌های کدنویسی C++ GCC</a></li><li><a href="http://www.python.org/dev/peps/pep-0008/" title="راهنمای شیوه کدنویسی در پایتون" target="_blank">راهنمای شیوه کدنویسی در پایتون</a></li></ul><h3>منابع</h3><div class="ltr"><ul><li><a href="http://en.wikipedia.org/wiki/Coding_conventions" title="Coding conventions" target="_blank">Coding conventions (Wikipedia)</a></li><li><a href="http://en.wikipedia.org/wiki/Software_peer_review" title="Software peer review" target="_blank">Software peer review</a></li><li><a href="http://marakana.com/bookshelf/java_fundamentals_tutorial/javadoc.html" title="Java Fundamentals Tutorial : Javadoc" target="_blank">Java Fundamentals Tutorial : Javadoc</a></li><li><a href="http://www.oracle.com/technetwork/java/codeconv-138413.html" title="Code Conventions for the Java Programming Language" target="_blank">Code Conventions for the Java Programming Language</a></li></ul></div><p>منبع تصویر:<a href="http://www.onlinedegrees.org/calculator/salary/computer-programmers" title="Computer Programmer Career" target="_blank"> onlinedegrees.org</a></p><p>شاد و پیروز باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25a7%25d9%2587%25d8%25af%25d9%2587%25e2%2580%258c%25d9%2587%25d8%25a7%25db%258c-%25da%25a9%25d8%25af-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25db%258c-coding-conventions%2F&amp;linkname=%D9%85%D8%B9%D8%A7%D9%87%D8%AF%D9%87%E2%80%8C%D9%87%D8%A7%DB%8C%20%DA%A9%D8%AF%D9%86%D9%88%DB%8C%D8%B3%DB%8C%20%28Coding%20conventions%29" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25a7%25d9%2587%25d8%25af%25d9%2587%25e2%2580%258c%25d9%2587%25d8%25a7%25db%258c-%25da%25a9%25d8%25af-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25db%258c-coding-conventions%2F&amp;linkname=%D9%85%D8%B9%D8%A7%D9%87%D8%AF%D9%87%E2%80%8C%D9%87%D8%A7%DB%8C%20%DA%A9%D8%AF%D9%86%D9%88%DB%8C%D8%B3%DB%8C%20%28Coding%20conventions%29" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25a7%25d9%2587%25d8%25af%25d9%2587%25e2%2580%258c%25d9%2587%25d8%25a7%25db%258c-%25da%25a9%25d8%25af-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25db%258c-coding-conventions%2F&amp;linkname=%D9%85%D8%B9%D8%A7%D9%87%D8%AF%D9%87%E2%80%8C%D9%87%D8%A7%DB%8C%20%DA%A9%D8%AF%D9%86%D9%88%DB%8C%D8%B3%DB%8C%20%28Coding%20conventions%29" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25a7%25d9%2587%25d8%25af%25d9%2587%25e2%2580%258c%25d9%2587%25d8%25a7%25db%258c-%25da%25a9%25d8%25af-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25db%258c-coding-conventions%2F&amp;linkname=%D9%85%D8%B9%D8%A7%D9%87%D8%AF%D9%87%E2%80%8C%D9%87%D8%A7%DB%8C%20%DA%A9%D8%AF%D9%86%D9%88%DB%8C%D8%B3%DB%8C%20%28Coding%20conventions%29" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d9%2585%25d8%25b9%25d8%25a7%25d9%2587%25d8%25af%25d9%2587%25e2%2580%258c%25d9%2587%25d8%25a7%25db%258c-%25da%25a9%25d8%25af-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25db%258c-coding-conventions%2F&amp;title=%D9%85%D8%B9%D8%A7%D9%87%D8%AF%D9%87%E2%80%8C%D9%87%D8%A7%DB%8C%20%DA%A9%D8%AF%D9%86%D9%88%DB%8C%D8%B3%DB%8C%20%28Coding%20conventions%29" id="wpa2a_6">اشتراک‌گذاری</a></p><p>مطلب مرتبطی یافت نشد.</p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d9%85%d8%b9%d8%a7%d9%87%d8%af%d9%87%e2%80%8c%d9%87%d8%a7%db%8c-%da%a9%d8%af-%d9%86%d9%88%db%8c%d8%b3%db%8c-coding-conventions/feed/</wfw:commentRss> <slash:comments>9</slash:comments> </item> <item><title>انواع داده در MySQL</title><link>http://zebardast.ir/%d8%a7%d9%86%d9%88%d8%a7%d8%b9-%d8%af%d8%a7%d8%af%d9%87-%d9%87%d8%a7-%d8%af%d8%b1-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/</link> <comments>http://zebardast.ir/%d8%a7%d9%86%d9%88%d8%a7%d8%b9-%d8%af%d8%a7%d8%af%d9%87-%d9%87%d8%a7-%d8%af%d8%b1-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/#comments</comments> <pubDate>Wed, 23 Nov 2011 13:08:08 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[پایگاه داده MySQL]]></category> <category><![CDATA[مای‌اس‌کیوال]]></category> <category><![CDATA[پایگاه داده]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1527</guid> <description><![CDATA[— MySQL سلام، هدف این مقاله بررسی انواع داده ها در پایگاه داده MySQL (مای‌اس‌کیوال) می باشد. MySQL انواع مختلف داده را در دسته بندی های زیر پشتیبانی می کند: اعداد (Numeric) زمان (Date and Time) رشته ها (String) داده های فضایی (Spatial) در این مقاله داده های عددی، زمان و رشته ها را بررسی [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%a7%d8%b2-%d9%81%d8%a7%db%8c%d9%84-%d8%a8%d9%87-mysql/' rel='bookmark' title='وارد کردن اطلاعات از فایل به پایگاه داده MySQL'>وارد کردن اطلاعات از فایل به پایگاه داده MySQL</a></li><li><a href='http://zebardast.ir/%d9%86%da%a9%d8%a7%d8%aa%db%8c-%d8%af%d8%b1-%d8%b2%d9%85%db%8c%d9%86%d9%87-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/' rel='bookmark' title='نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL'>نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%a7%d8%b2%db%8c%d8%a7%d8%a8%db%8c-%d8%af%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql-%d9%82%d8%b3%d9%85%d8%aa-%d8%a7%d9%88%d9%84/' rel='bookmark' title='بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول'>بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول</a></li></ol>]]></description> <content:encoded><![CDATA[<div class="autocap alignleft" style="width: 110px;"><div><a href="http://zebardast.ir/wp-content/uploads/2010/10/logo-mysql-110x57.png"><img src="http://zebardast.ir/wp-content/uploads/2010/10/logo-mysql-110x57.png" alt="" title="MySQL" width="110" height="57" class=" size-full wp-image-1157" /></a><p class="autocap-text"><span class="hide">— </span>MySQL</p></div></div><p>سلام،<br /> هدف این مقاله بررسی انواع داده ها در پایگاه داده MySQL (مای‌اس‌کیوال) می باشد. MySQL انواع مختلف داده را در دسته بندی های زیر پشتیبانی می کند:</p><ul><li>اعداد (Numeric)</li><li>زمان (Date and Time)</li><li>رشته ها (String)</li><li>داده های فضایی (Spatial)</li></ul><p>در این مقاله داده های عددی، زمان و رشته ها را بررسی می کنیم. با توجه به تخصصی بودن داده های فضایی، این نوع داده ها را در مقاله ای جداگانه در آینده بررسی خواهیم کردم.</p><h3>اعداد (Numeric)</h3><p>MySQL تمامی انواع داده های عددی استاندارد SQL شامل اعداد صحیح و اعداد تقریبی را پشتبانی می کند.  هر یک از نوع داده های عددی حافظه مشخصی برای ذخیره سازی نیاز دارند. همچنین در نظر داشته باشید که هر کدام از آنها محدوده مشخصی را پشتیبانی می کنند. هر نوع از این داده های عددی را می توان به صورت SIGNED یا UNSIGNED تعریف کرد. در حالت SIGNED این ستون ها از مقادیر منفی پشتبیبانی می کنند ولی در حالت UNSIGNED اعداد ذخیره شده باید بزرگتر ویا مساوی صفر باشند. در نظر داشته باشید که نوع داده <code>BOOLEAN</code> برای ذخیره مقادیر <code>TRUE</code> و <code>FALSE</code> همان <code>TINYINT(1)</code> می باشد.<br /> جدول زیر اطلاعات کلی نوع داده های عددی را در حالت SIGNED و UNSIGNED نشان می دهد:</p><table class="info" cellpadding=0 cellspacing=0><caption>اطلاعات کلی نوع داده های عددی Integer</caption><thead><tr><th>نوع</th><th>حافظه (بایت)</th><th> حداقل مقدار</th><th> حداکثر مقدار</th><th> توضیحات</th></tr></thead><tbody><tr><td class="ltr" rowspan="2">TINYINT</td><td rowspan="2">1</td><td class="ltr">-128</td><td class="ltr">127</td><td></td></tr><tr><td class="ltr">0</td><td class="ltr">255</td><td></td></tr><tr><td class="ltr" rowspan="2">SMALLINT</td><td rowspan="2">2</td><td class="ltr">-32768</td><td class="ltr">32767</td><td></td></tr><tr><td class="ltr">0</td><td class="ltr">65535</td><td></td></tr><tr><td class="ltr" rowspan="2">MEDIUMINT</td><td rowspan="2">3</td><td class="ltr">-8388608</td><td class="ltr">8388607</td><td></td></tr><tr><td class="ltr">0</td><td class="ltr">16777215</td><td></td></tr><tr><td class="ltr" rowspan="2">INTEGER</td><td rowspan="2">4</td><td class="ltr">-2147483648</td><td class="ltr">2147483647</td><td></td></tr><tr><td class="ltr">0</td><td class="ltr">4294967295</td><td></td></tr><tr><td class="ltr" rowspan="2">BIGINT</td><td rowspan="2">8</td><td class="ltr">-9223372036854775808</td><td class="ltr">9223372036854775807</td><td></td></tr><tr><td class="ltr">0</td><td class="ltr">18446744073709551615</td><td></td></tr></tbody></table><table class="info" cellpadding=0 cellspacing=0><caption>اطلاعات کلی نوع داده های عددی شناور</caption><thead><tr><th>نوع</th><th>حافظه (بایت)</th><th> مقدار</th><th> نحوه تعریف</th><th> توضیحات</th></tr></thead><tbody><tr><td class="ltr">FLOAT</td><td>4</td><td>از ۰ تا ۲۳ رقم</td><td class="ltr">FLOAT(M,D)</td><td>مقدار تقریبی (Approximate Value)</td></tr><tr><td class="ltr">DOUBLE</td><td>8</td><td>از ۲۴ تا ۵۳ رقم</td><td class="ltr">DOUBLE(M,D)</td><td>مقدار تقریبی (Approximate Value)</td></tr><tr><td class="ltr">DECIMAL</td><td>هر ۹ رقم ۴ بایت به صورت باینری</td><td>تا ۶۵ رقم</td><td class="ltr">DECIMAL(M,D)</td><td>مقدار دقیق (Exact Value)</td></tr></tbody></table><p>در جدول بالا حرف M نشان‌دهنده تعداد کل رقم‌های  داده و حرف D نشان‌دهنده تعداد رقم‌های بعد از ممیز (.) می باشد. به عنوان مثال در ستونی که به صورت <code>FLOAT(7,4)</code> تعریف شده است می توان حداکثر مقدار 999.9999 را ذخیره نمود. در صورتی که شما عدد 999.00009 را به این جدول وارد کنید، عدد واردشده به صورت 999.0001 ذخیره خواهد شد.</p><p><strong>سوال</strong>: منظور از مقدار تقریبی و دقیق در جدول داده های عددی شناور چیست؟<br /> <strong>پاسخ</strong>: گاهی اوقات در نوع داده‌های تقریبی اعداد گرد می شوند. در زیر با اجرا کردن چند دستور در خط فرمان MySQL پایگاه داده‌ای با دو ستون Decimal و Float تعریف کردیم. در آخرین دستور نتیجه گردشدن را در ستون Float مشاهده می فرمایید:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; create table numbers (a decimal(10,2), b float);
mysql&gt; insert into numbers values (100, 100);
mysql&gt; select @a := (a/3), @b := (b/3), @a * 3, @b * 3 from numbers \G
*************************** 1. row ***************************
@a := (a/3): 33.333333333
@b := (b/3): 33.3333333333333
     @a * 3: 99.999999999
     @b * 3: 100
</pre><p>برای اطلاعات بیشتر به صفحه <a href="http://dev.mysql.com/doc/refman/5.0/en/problems-with-float.html" title="Problems with Floating-Point Values" target="_blank">Problems with Floating-Point Values</a> در سایت MySQL مراجعه نمایید.<br /> در نسخه های قبل از 5.0.3 نوع داده DECIMAL به صورت String ذخیره می شود و مقدار رقم‌هایی که پشتیبانی می کرد مانند نوع داده DOUBLE بود.</p><h4>نوع داده BIT</h4><p>این نوع داده برای ذخیره بیت‌های ۰ و ۱ استفاده می شود. برای تعریف ستونی از این نوع از عبارت <code>BIT(M)</code> استفاده می کنیم که در اینجا M فضایی به طول تقریبا <code>(M+7)/8</code> بایت را برای نگهداری داده‌ها ایجاد می کند. M می تواند عددی از ۱ تا ۶۴ باشد. برای نشان‌دادن ۰ و ۱ به صورت بیت از حرف b استفاده می کنیم. به عنوان مثال <code>b'111'</code> و <code>b'10000000'</code> که به ترتیب برابر اعداد ۷ و ۱۲۸ می باشند. برای درک بیشتر این موضوع به دستورات و نتایج زیر در خط فرمان MySQL توجه فرمایید:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; INSERT INTO t SET b = b'11111111';
mysql&gt; INSERT INTO t SET b = b'1010';
mysql&gt; INSERT INTO t SET b = b'0101';
mysql&gt; SELECT b+0, BIN(b+0), OCT(b+0), HEX(b+0) FROM t;
+------+----------+----------+----------+
| b+0  | BIN(b+0) | OCT(b+0) | HEX(b+0) |
+------+----------+----------+----------+
|  255 | 11111111 | 377      | FF       |
|   10 | 1010     | 12       | A        |
|    5 | 101      | 5        | 5        |
+------+----------+----------+----------+
3 rows in set (0.03 sec)
</pre><p>آخرین Query در بالا توابع مختلف برای تبدیل این اعداد را نشان می دهد. عبارت <code>+0</code> مقدار دودویی ذخیره شده را به عدد ده‌دهی متناظر تبدیل می کند.</p><h3>زمان (Date and Time)</h3><p>در کل ۵ نوع داده برای ذخیره زمان (ساعت و تاریخ) داریم. در جدول زیر اطلاعات این نوع داده‌ها را مشاهده می‌فرمایید:</p><table class="info" cellpadding=0 cellspacing=0><caption>اطلاعات کلی نوع داده های زمانی (Date and Time)</caption><thead><tr><th>نوع</th><th>حافظه (بایت)</th><th> مقدار صفر <code>(“Zero” Value)</code></th></tr></thead><tbody><tr><td class="ltr">DATE</td><td>3</td><td class="ltr"><code>'0000-00-00'</code></td></tr><tr><td class="ltr">TIME</td><td>3</td><td class="ltr"><code>'00:00:00'</code></td></tr><tr><td class="ltr">DATETIME</td><td>8</td><td class="ltr"><code>'0000-00-00 00:00:00'</code></td></tr><tr><td class="ltr">TIMESTAMP</td><td>4</td><td class="ltr"><code>'0000-00-00 00:00:00'</code></td></tr><tr><td class="ltr">YEAR</td><td>1</td><td class="ltr"><code>0000</code></td></tr></tbody></table><p>در ادامه به بررسی نوع داده‌های ذکر شده در بالا خواهیم پرداخت.</p><h4>نوع داده DATE</h4><p>این نوع داده فقط برای ذخیره سازی تاریخ استفاده می شود. فرمت پیش فرض این نوع داده <code>'YYYY-MM-DD'</code> است. بازه‌ای که توسط DATE پشتیبانی می شود از <code>'1000-01-01'</code> تا <code>'9999-12-31'</code> می باشد.</p><h4>نوع داده TIME</h4><p>این نوع داده برای ذخیره سازی زمان (ساعت، دقیقه، ثانیه) استفاده می شود. فرمت پیش‌فرض این نوع داده <code>'HH:MM:SS'</code> و یا <code>'HHH:MM:SS'</code> است. بازه ای که در نوع TIME پشتیبانی می شود از <code>'-838:59:59'</code> تا <code>'838:59:59'</code> می باشد. نوع داده TIME فقط برای نمایش زمان روز استفاده نمی شود. برای نمایش تفاوت زمانی دو بازه و یا زمان باقی‌مانده نیز می تواند از TIME استفاده نمود. به همین دلیل بازه پشتیبانی شده بیشتر از ۲۴ ساعت و یا کمتر از صفر (منفی) می باشد.<br /> برای استفاده از عبارت های مخفف در نوع داده TIME باید دقت نمایید. به عنوان مثال MySQL عبارت <code>'11:12'</code> را به صورت <code>'11:12:00'</code> تفسیر می کند. در صورتی که داده بدون <code>':'</code> (دو نقطه) بیان شود، MySQL آن را از سمت راست تفسیر می کند. به عنوان مثال عبارت <code>'1112'</code> و یا <code>1112</code> به معنی <code>'00:11:12'</code> است.<br /> به صورت پیش فرض MySQL داده‌های خارج از محدوده TIME را در صورتی که با فرمت مناسب وارد شده باشند به نزدیک‌ترین بازه تبدیل می کند. به عنوان مثال عبارت‌های <code>'-850:00:00'</code> و <code>'850:00:00'</code> به <code>'-838:59:59'</code> و <code>'838:59:59'</code> تبدیل خواهند شد. داده‌هایی که فرمت مناسب نداشته و یا قابل تفسیر برای داده TIME نباشند به عبارت <code>'00:00:00'</code> تبدیل خواهند شد.</p><h4>نوع داده DATETIME</h4><p>این نوع داده برای ذخیره سازی زمان به صورت کامل شامل تاریخ و ساعت استفاده می شود. فرمت پیش فرض این نوع داده <code>'YYYY-MM-DD HH:MM:SS'</code> می باشد. بازه‌ی پشتیبانی DATETIME از <code>'1000-01-01 00:00:00'</code> تا <code>'9999-12-31 23:59:59'</code> است.</p><h4>نوع داده TIMESTAMP</h4><p>این نوع داده همانند DATETIME می باشد. بازه‌ای که توسط TIMESTAMP پشتیبانی می‌شود از <code>'1970-01-01 00:00:01' <abbr title="ساعت هماهنگ جهانی - Coordinated Universal Time">UTC</abbr></code> تا <code>'2038-01-19 03:14:07' <abbr title="ساعت هماهنگ جهانی - Coordinated Universal Time">UTC</abbr></code> است.<br /> داده‌های TIMESTAMP هنگام ذخیره شدن از زمان منطقه زمانی (Time Zone) کنونی سیستم به UTC تبدیل و ذخیره می شوند. متناظر با همین امر، هنگام نشان دادن داده‌های TIMESTAMP، ابتدا داده‌ها از UTC به منطقه زمانی کنونی سیستم تبدیل شده و بعد نمایش داده می شوند. به همین علت در صورتی که منطقی زمانی سیستم عوض شود، ممکن است داده‌ها به صورت غیرعادی و یا غلط نمایش داده شوند.<br /> نوع داده TIMESTAMP این قابلیت را دارد که مقداردهی اولیه و یا مقداردهی خودکار داشته باشید. برای مقداردهی اولیه کافیست مقدار پیش فرض فیلد مورد نظر را CURRENT_TIMESTAMP قرار دهید. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; CREATE TABLE t (ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP);
</pre><p>در حالت مقداردهی خودکار، مقدار ذخیره شده در فیلد TIMESTAMP هنگام بروزرسانی (UPDATE) یک ردیف به زمان بروزرسانی تغییر پیدا می کند. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; CREATE TABLE t (name VARCHAR(100), ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP);

mysql&gt; INSERT INTO t(name) VALUES('Saeid');

mysql&gt; SELECT * FROM t;
+-------+---------------------+
| name  | ts                  |
+-------+---------------------+
| Saeid | 2011-12-22 12:00:26 |
+-------+---------------------+
1 row in set (0.00 sec)

mysql&gt; UPDATE t SET name = 'Alireza';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql&gt; SELECT * FROM t;
+---------+---------------------+
| name    | ts                  |
+---------+---------------------+
| Alireza | 2011-12-22 12:01:56 |
+---------+---------------------+
1 row in set (0.00 sec)
</pre><p>برای کسب اطلاعات بیشتر به صفحه <a href="http://dev.mysql.com/doc/refman/5.0/en/timestamp.html" title="TIMESTAMP Properties" target="_blank">TIMESTAMP Properties</a> در سایت MySQL مراجعه نمایید.</p><h4>نوع داده YEAR</h4><p>این نوع داده برای ذخیره سازی سال با فرمت YYYY به کار می‌رود. شما می تواند سال مورد نظر خود را به صورت دو رقمی <code>YEAR(2)</code> و یا ۴ رقمی <code>YEAR(4)</code> تعریف کنید. نوع YEAR از سال 1901 تا 2155 و 0000 را پشتیبانی می کند. در صورتی که سال را به صورت ۲ رقمی تعریف کرده باشید، اعداد 00 تا 69 در قرن ۲۱ و اعداد 70 تا 99 در قرن ۲۰ در نظر گرفته می شوند. مثلا 45 به عنوان 2045 و 80 به صورت 1980 در نظر گرفته می شود. تمامی مقادیر غیر منطقی برای YEAR به صورت 0000 ذخیره می شوند.</p><h3>رشته ها (String)</h3><p>نوع داده String برای نگه داری رشته‌ها (متون) استفاده می شود. در زیر اطلاعات کلی داده هایی از نوع String را مشاهده می فرمایید. در جدول زیر M نشان‌دهنده طول تعریف شده برای داده و L نشان‌دهنده طول واقعی رشته داده شده می باشد.</p><table class="info" cellpadding=0 cellspacing=0><caption>اطلاعات کلی نوع داده رشته‌ها (String)</caption><thead><tr><th>نوع</th><th> مقدار</th><th>حافظه (بایت)</th></tr></thead><tbody><tr><td class="ltr"><code>CHAR(M)</code></td><td class="ltr" nowrap="nowrap"><code>0 <= M <= 255</code></td><td> <code>M × w</code> بایت. w تعداد بایت مورد نیاز برای حداکثر طول کاراکترهای تعریف شده در character set جدول می باشد.</td></tr><tr><td class="ltr"><code>BINARY(M)</code></td><td class="ltr" nowrap="nowrap"><code>0 <= M <= 255</code></td><td> M بایت</td></tr><tr><td class="ltr"><code>VARCHAR(M)</code></td><td class="ltr" nowrap="nowrap"><code>0 <= M <= 65532</code></td><td> <code>L + 1</code> بایت اگر داده مورد نظر کمتر از ۲۵۵ بایت نیاز داشته باشد.<br /> <code>L + 2</code> بایت اگر داده مورد نظر بیشتر از ۲۵۵ بایت نیاز داشته باشد.</td></tr><tr><td class="ltr"><code>VARBINARY(M)</code></td><td class="ltr" nowrap="nowrap"><code>0 <= M <= 65532</code></td><td> <code>M + 1</code> بایت اگر داده مورد نظر کمتر از ۲۵۵ بایت نیاز داشته باشد.<br /> <code>M + 2</code> بایت اگر داده مورد نظر بیشتر از ۲۵۵ بایت نیاز داشته باشد.</td></tr><tr><td class="ltr"><code>TINYBLOB</code></td><td class="ltr"><code>L < 2<sup>8</sup></code></td><td><code>L + 1</code> بایت</td></tr><tr><td class="ltr"><code>TINYTEXT</code></td><td class="ltr"><code>L < 2<sup>8</sup></code></td><td><code>L + 1</code> بایت</td></tr><tr><td class="ltr"><code>BLOB</code></td><td class="ltr"><code>L < 2<sup>16</sup></code></td><td><code>L + 2</code> بایت</td></tr><tr><td class="ltr"><code>TEXT</code></td><td class="ltr"><code>L < 2<sup>16</sup></code></td><td><code>L + 2</code> بایت</td></tr><tr><td class="ltr"><code>MEDIUMBLOB</code></td><td class="ltr"><code>L < 2<sup>24</sup></code></td><td><code>L + 3</code> بایت</td></tr><tr><td class="ltr"><code>MEDIUMTEXT</code></td><td class="ltr"><code>L < 2<sup>24</sup></code></td><td><code>L + 3</code> بایت</td></tr><tr><td class="ltr"><code>LONGBLOB</code></td><td class="ltr"><code>L < 2<sup>32</sup></code></td><td><code>L + 4</code> بایت</td></tr><tr><td class="ltr"><code>LONGTEXT</code></td><td class="ltr"><code>L < 2<sup>32</sup></code></td><td><code>L + 4</code> بایت</td></tr><tr><td class="ltr"><code>ENUM('v1','v2',...)</code></td><td>حداکثر ۶۵,۵۳۵ عضو</td><td>۱ یا ۲ بایت.<br /> وابسته به مقدار داده.</td></tr><tr><td class="ltr"><code>SET('v1','v2',...)</code></td><td>حداکثر ۶۴ عضو</td><td>۱، ۲، ۳، ۴ یا ۸ بایت<br /> وابسته به مجموعه داده شده.</td></tr></tbody></table><h4>نوع داده CHAR و VARCHAR</h4><p>CHAR و VARCHAR بسیار شبیه به هم هستند. مهم‌ترین تفاوتی که بین CHAR و VARCHAR وجود دارد نحوه ذخیره سازی و بازیابی اطلاعات است. هنگام تعریف این نوع داده‌ها شما حداکثر تعداد کاراکتری را که می خواهید ذخیره شود را مشخص می نمایید. به عنوان مثال <code>CHAR(30)</code> برای ذخیره حداکثر ۳۰ کاراکتر تعریف می شود.<br /> طول ستونی که از نوع CHAR باشد ثابت است. در صورتی که طول داده کمتر از طول تعریف شده باشد، فضای باقیمانده با فاصله <code>(space)</code> از راست پر می‌شود. هنگام بازیابی اطلاعات این فضای خالی قبل از نمایش حذف می‌شود مگر اینکه حالت <a href="http://dev.mysql.com/doc/refman/5.6/en/server-sql-mode.html#sqlmode_pad_char_to_full_length" title="PAD_CHAR_TO_FULL_LENGTH " target="_blank">PAD_CHAR_TO_FULL_LENGTH</a> فعال شده باشد.<br /> در نوع داده VARCHAR طول داده ذخیره شده به اندازه مقدار داده وارد شده می باشد. به عنوان مثال اگر ستونی به صورت <code>VARCHAR(100)</code> تعریف شده باشد ولی طول رشته داده شده 50 کاراکتر باشد، فقط به مقدار بایت زیر فضا لازم است.<br /> <code></p><div style="text-align:right; direction:rtl; border:1px dashed #333; padding: 0 5px;"> (50 * فضای لازم برای ذخیره هر کاراکتر) + 2</div><p></code><br /> در صورتی که در تعریف <code>VARCHAR(M)</code> مقدار M بیشتر از ۶۵,۵۳۵ باشد، MySQL به طور خودکار نوع ستون را از <code>VARCHAR</code> به نوع مناسبی مانند <code>MEDIUMTEXT</code> تغییر می دهد.</p><p>جدول زیر تفاوت‌های فضای مورد نیاز برای ذخیره اطلاعات را در CHAR و VARCHAR نمایش می دهد. دقت کنید که در جدول زیر Character Set  داده مورد نظر تک بایتی مانند latin1 است.</p><table class="info" cellpadding=0 cellspacing=0><caption>بررسی تفاوت فضای مورد نیاز برای <code>CHAR(4)</code> و <code>VARCHAR(4)</code></caption><col><colgroup span="2" style="background-color:#ffc;"></colgroup><colgroup span="2" style="background-color:#cfc;"></colgroup><thead><tr><th>داده</th><th class="ltr"><code>CHAR(4)</code></th><th>فضای مورد نیاز</th><th class="ltr"><code>VARCHAR(4)</code></th><th>فضای مورد نیاز</th></tr></thead><tbody><tr><td class="ltr"><code>''</code></td><td class="ltr"><code>'&nbsp;&nbsp;&nbsp;&nbsp;'</code></td><td>۴ بایت</td><td class="ltr"><code>''</code></td><td>۱ بایت</td></tr><tr><td class="ltr"><code>'ab'</code></td><td class="ltr"><code>'ab&nbsp;&nbsp;'</code></td><td>۴ بایت</td><td class="ltr"><code>'ab'</code></td><td>۳ بایت</td></tr><tr><td class="ltr"><code>'abcd'</code></td><td class="ltr"><code>'abcd'</code></td><td>۴ بایت</td><td class="ltr"><code>'abcd'</code></td><td>۵ بایت</td></tr><tr><td class="ltr"><code>'abcdefgh'</code></td><td class="ltr"><code>'abcd'</code></td><td>۴ بایت</td><td class="ltr"><code>'abcd'</code></td><td>۵ بایت</td></tr></tbody></table><h4>نوع داده BINARY و VARBINARY</h4><p>این نوع داده ها مانند CHAR و VARCHAR می باشند فقط با این تفاوت که در این نوع داده‌ها رشته‌های باینری (صفر و یک) ذخیره می شود. در نتیجه Character set برای این نوع داده‌ها معنی ندارد. از طرفی مرتب‌سازی و مقایسه بر اساس مقدار عددی رشته باینری ذخیره شده می باشد.</p><h4>نوع داده BLOB و TEXT</h4><p>این نوع داده‌ها مانند BINARY و VARBINARY می باشند. هر کدام از این داده‌ها دارای ۴ نوع می‌باشند که تنها تفاوت آن‌ها در حداکثر طول داده قابل ذخیره شدن است.</p><h4>نوع داده ENUM</h4><p>این نوع داده فقط امکان ذخیره سازی رشته ای را می دهد که از مجموعه تعریف شده باشد. این مجموعه هنگام ساخت جدول تعریف می شود. مانند جدول زیر:</p><pre class="brush: sql; title: ; notranslate">
CREATE TABLE sizes (
    name ENUM('small', 'medium', 'large')
);
</pre><p>در ستون name در جدول بالا فقط می توانید یکی از مقادیر small، medium یا large را ذخیره نمایید. در صورتی که مقداری خارج از مجموعه وارد مجموعه شود، فضای خالی در name ذخیره می شود، نه مقدار وارد شده.</p><h4>نوع داده SET</h4><p>این نوع داده مانند ENUM می باشد، با این تفاوت که شما می توانید چند عضو از مجموعه تعریف شده را انتخاب نمایید. توجه نمایید که یا داده‌های تکراری قبل از ذخیره سازی حذف می شوند. به مثال زیر توجه فرمایید:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
Query OK, 0 rows affected (0.05 sec)

mysql&gt; INSERT INTO myset (col) VALUES  ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
Query OK, 5 rows affected (0.00 sec)
Records: 5  Duplicates: 0  Warnings: 0

mysql&gt; SELECT col FROM myset;
+------+
| col  |
+------+
| a,d  |
| a,d  |
| a,d  |
| a,d  |
| a,d  |
+------+
5 rows in set (0.00 sec)
</pre><p>از قراردادن فاصله قبل و یا بعد ',' جدا خوددداری نمایید.</p><h3>چطور نوع داده مناسب را انتخاب نماییم؟</h3><p>قبل از هر چیز بازه‌ی مورد نیاز برای داده خود را معین نمایید. سپس مختصرترین نوع داده را برای ستون خود انتخاب نمایید. به عنوان مثال برای بازه اعداد ۰ تا ۹۹۹۹۹ نوع <code>MEDIUMINT UNSIGNED</code> بهترین گزینه است.<br /> مورد دیگر انتخاب نوع ستون مناسب با داده شما است. به عنوان مثال هرگز تاریخ شمسی را در پایگاه داده در ستونی از نوع رشته (مانند <code>CHAR</code>) ذخیره ننمایید. بهترین گزینه تبدیل تاریخ به تاریخ میلای و ذخیره آن در داده‌ای از نوع <code>DATE</code> است.<br /> در هنگام تعریف ستونی برای داده‌های عددی در صورتی که فقط اعداد مثبت را لازم دارید، ستون خود را از نوع UNSIGNED انتخاب نموده و حداقل بازه را انتخاب نمایید. به عنوان مثال اگر ستون عددی شما کلید اصلی و افزایشی خودکار است (PRIMAY KEY and AUTO_INCREMENT) حتما نوع داده خود را UNSIGNED انتخاب نمایید تا حداکثر مقدار کلید اصلی دو برابر شود. نوع INTEGER SIGNED حداکثر عدد 2147483648 (حدود ۲ میلیارد) و INTEGER UNSIGNED حداکثر عدد 4294967295 (حدود ۴ میلیارد) را پشتیبانی می کند.</p><p>روش دیگر استفاده از <code>PROCEDURE ANALYSE</code> به منظور دریافت پیشنهاد خود پایگاه داده است. <code>PROCEDURE ANALYSE</code> با توجه به داده‌های فعلی، پیشنهاد خود را برای بهینه کردن نوع داده ارائه می دهد. در نظر داشته باشید که هر چه تعداد داده فعلی شما بیشتر باشد، <code>PROCEDURE ANALYSE</code> پیشنهاد بهتر و دقیق‌تری می دهد. نحوه استفاده از <code>PROCEDURE ANALYSE</code> بسیار ساده است. نحوه نگارش آن به صورت زیر است:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; SELECT ... FROM ... WHERE ... PROCEDURE ANALYSE([max_elements,[max_memory]]);
</pre><p>مانند:</p><pre class="brush: sql; title: ; notranslate">
SELECT col1, col2 FROM table1 PROCEDURE ANALYSE(10, 2000);
</pre><p>یا</p><pre class="brush: sql; title: ; notranslate">
SELECT * FROM table1 PROCEDURE ANALYSE() \G
</pre><h3>اسامی مشابه</h3><p>در پایگاه داده MySQL برخی از انواع داده‌ها با نام‌های مشابه دیگری نیز قابل دسترسی می باشند. یکی از دلایل این کار پیاده سازی راحت‌تر SQL های پایگاه‌های داده‌ی دیگر است. در زیر این اسامی را مشاهده می نمایید.</p><table class="info" cellpadding=0 cellspacing=0><caption>اسامی مشابه برای نوع داده‌ها در MySQL</caption><thead><tr><th>نوع داده</th><th>اسم مشابه</th></tr></thead><tbody><tr><td class="ltr">INTEGER</td><td class="ltr">INT</td></tr><tr><td class="ltr">DECIMAL</td><td class="ltr">DEC</td></tr><tr><td class="ltr">DECIMAL</td><td class="ltr">FIXED</td></tr><tr><td class="ltr">DECIMAL</td><td class="ltr">NUMERIC</td></tr><tr><td class="ltr">DOUBLE</td><td class="ltr">REAL</td></tr></tr><tr><td class="ltr">TINYINT</td><td class="ltr">BOOLEAN</td></tr><tr><td class="ltr">TINYINT</td><td class="ltr">BOOL</td></tr><tr><td class="ltr">VARCHAR(M)</td><td class="ltr">CHARACTER VARYING(M)</td></tr><tr><td class="ltr">FLOAT</td><td class="ltr">FLOAT4</td></tr><tr><td class="ltr">DOUBLE</td><td class="ltr">FLOAT8</td></tr><tr><td class="ltr">TINYINT</td><td class="ltr">INT1</td></tr><tr><td class="ltr">SMALLINT</td><td class="ltr">INT2</td></tr><tr><td class="ltr">MEDIUMINT</td><td class="ltr">INT3</td></tr><tr><td class="ltr">INT</td><td class="ltr">INT4</td></tr><tr><td class="ltr">BIGINT</td><td class="ltr">INT8</td></tr><tr><td class="ltr">MEDIUMBLOB</td><td class="ltr">LONG VARBINARY</td></tr><tr><td class="ltr">MEDIUMTEXT</td><td class="ltr">LONG VARCHAR</td></tr><tr><td class="ltr">MEDIUMTEXT</td><td class="ltr">LONG</td></tr><tr><td class="ltr">MEDIUMINT</td><td class="ltr">MIDDLEINT</td></tr></tbody></table><p><strong>منابع</strong></p><ul><li><a href="http://dev.mysql.com/doc/" title="MySQL Reference Manual" target="_blank">MySQL Reference Manual</a></li></ul><p>شاد و موفق باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a7%25d9%2586%25d9%2588%25d8%25a7%25d8%25b9-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-%25d9%2587%25d8%25a7-%25d8%25af%25d8%25b1-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D8%A7%D9%86%D9%88%D8%A7%D8%B9%20%D8%AF%D8%A7%D8%AF%D9%87%20%D8%AF%D8%B1%20MySQL" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a7%25d9%2586%25d9%2588%25d8%25a7%25d8%25b9-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-%25d9%2587%25d8%25a7-%25d8%25af%25d8%25b1-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D8%A7%D9%86%D9%88%D8%A7%D8%B9%20%D8%AF%D8%A7%D8%AF%D9%87%20%D8%AF%D8%B1%20MySQL" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a7%25d9%2586%25d9%2588%25d8%25a7%25d8%25b9-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-%25d9%2587%25d8%25a7-%25d8%25af%25d8%25b1-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D8%A7%D9%86%D9%88%D8%A7%D8%B9%20%D8%AF%D8%A7%D8%AF%D9%87%20%D8%AF%D8%B1%20MySQL" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a7%25d9%2586%25d9%2588%25d8%25a7%25d8%25b9-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-%25d9%2587%25d8%25a7-%25d8%25af%25d8%25b1-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D8%A7%D9%86%D9%88%D8%A7%D8%B9%20%D8%AF%D8%A7%D8%AF%D9%87%20%D8%AF%D8%B1%20MySQL" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d8%25a7%25d9%2586%25d9%2588%25d8%25a7%25d8%25b9-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-%25d9%2587%25d8%25a7-%25d8%25af%25d8%25b1-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;title=%D8%A7%D9%86%D9%88%D8%A7%D8%B9%20%D8%AF%D8%A7%D8%AF%D9%87%20%D8%AF%D8%B1%20MySQL" id="wpa2a_8">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%a7%d8%b2-%d9%81%d8%a7%db%8c%d9%84-%d8%a8%d9%87-mysql/' rel='bookmark' title='وارد کردن اطلاعات از فایل به پایگاه داده MySQL'>وارد کردن اطلاعات از فایل به پایگاه داده MySQL</a></li><li><a href='http://zebardast.ir/%d9%86%da%a9%d8%a7%d8%aa%db%8c-%d8%af%d8%b1-%d8%b2%d9%85%db%8c%d9%86%d9%87-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/' rel='bookmark' title='نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL'>نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%a7%d8%b2%db%8c%d8%a7%d8%a8%db%8c-%d8%af%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql-%d9%82%d8%b3%d9%85%d8%aa-%d8%a7%d9%88%d9%84/' rel='bookmark' title='بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول'>بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d8%a7%d9%86%d9%88%d8%a7%d8%b9-%d8%af%d8%a7%d8%af%d9%87-%d9%87%d8%a7-%d8%af%d8%b1-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>عادت های بد برنامه نویسان</title><link>http://zebardast.ir/%d8%b9%d8%a7%d8%af%d8%aa-%d9%87%d8%a7%db%8c-%d8%a8%d8%af-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%db%8c%d8%b3%d8%a7%d9%86/</link> <comments>http://zebardast.ir/%d8%b9%d8%a7%d8%af%d8%aa-%d9%87%d8%a7%db%8c-%d8%a8%d8%af-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%db%8c%d8%b3%d8%a7%d9%86/#comments</comments> <pubDate>Sun, 19 Jun 2011 03:20:50 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[برنامه نویسی]]></category> <category><![CDATA[کد]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1460</guid> <description><![CDATA[سلام در طول چند سالی که مشغول به برنامه نویسی هستم عادت های بدی را توسط خودم و بقیه برنامه نویسان مشاهده کرده ام. هدف از این مطلب گردآوری تعدادی از رفتارها و عادت های نادرست است که با شناختن آن ها می توان از رخ دادنشان جلوگیری کرد. همه بد کد می نویسند، جز [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%85%d8%b3%d8%a7%d9%81%d8%b1%d8%aa-%d8%a8%d9%85-%d9%88-devcheshmaknet/' rel='bookmark' title='مسافرت بم  و سفره برنامه نویسی من'>مسافرت بم  و سفره برنامه نویسی من</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%db%8c%d8%b3%db%8c/' rel='bookmark' title='برنامه نویسی'>برنامه نویسی</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-gconf-cleaner/' rel='bookmark' title='برنامه Gconf Cleaner'>برنامه Gconf Cleaner</a></li></ol>]]></description> <content:encoded><![CDATA[<p> سلام</p><p>در طول چند سالی که مشغول به برنامه نویسی هستم عادت های بدی را توسط خودم و بقیه برنامه نویسان مشاهده کرده ام. هدف از این مطلب گردآوری تعدادی از رفتارها و عادت های نادرست است که با شناختن آن ها می توان از رخ دادنشان جلوگیری کرد.</p><p><strong>همه بد کد می نویسند، جز من!</strong><br /> گاه اوقات یک برنامه نویس با دیدن کدهای شخص دیگر، به جای قبول کردن اختلاف نظر موجود در کدنویسی به زیر سوال بردن روش کدنویسی طرف مقابل می پردازد. درست است که در پروژه های تیمی رعایت استانداردهای تیم ضروریست، اما در مواردی که شخص در حال کار بر روی جزییات است و هیچ استانداردی را زیر سوال نبرده، بهتر است قبل از بحث در مورد کدهای نوشته شده، دیدگاه وی را در مورد این نوع کدنویسی بدانیم.<br /> <a href="http://zebardast.ir/wp-content/uploads/2011/06/control_cut_copy_paste.jpg"><img src="http://zebardast.ir/wp-content/uploads/2011/06/control_cut_copy_paste-150x150.jpg" alt="Control + Cut + Copy + P" title="Control + Cut + Copy + Paste" width="150" height="150" class="alignleft size-thumbnail wp-image-1473" /></a><br /> <strong>Copy &#038; Paste</strong><br /> یک از بدترین کارهایی که توسط برنامه نویس انجام می شود و علاوه بر خود به کل تیم و پروژه آسیب وارد کند، Copy و Paste کردن کدها بدون بررسی و فراگیری دانش موجود در آنهاست. این مورد بویژه در برنامه نویسان وب بسیار مشاهده می شود. بهتر است به جای کپی کردن کد از جای دیگری، نیاز خود را با فراگیری تکنیک های لازم رفع کنید. در صورتی که مجبور به نسخه برداری از کد دیگری هستید، بهتر است تک تک خطوط آن را بررسی کرده و لایسنس مربوط به آن را رعایت فرمایید. پیشنهاد می کنم صفحه <a href="http://en.wikipedia.org/wiki/Copy_and_paste_programming">Copy and paste programming در ویکی پدیا</a> را مطالعه کنید.</p><p><strong>نام گزاری نامفهوم متغیرها</strong><br /> این مشکل بیشتر در برنامه نویسان کم تجربه دیده می شود. مثلا متغییری را با حرف u تعریف کرده و در بخش های مختلف استفاده می کند. شما فکر می کنید که منظور از u همان user است، بعد شک می کنید که شاید username باشد و در آخر متوجه می شوید که منظور وی usability بوده است! درصورتی که نام متغییر را با توجه به محتوای آن ها برگزیده شود، خوانایی برنامه دوچندان می شود.</p><p><strong>این بخش خیلی زود تموم می شود</strong><br /> معمولا زمانی که یک بخش زودتر از موعد مقرر تمام می شود، بهتر است در مورد برنامه نوشته شده شک کنید! شاید برنامه نویس بخواهد با اینکار قدرت برنامه نویسی خود را نشان دهد ولی بارها دیده ام که بعد از چندین هفته و ماه، ایرادی در چنین برنامه ای رخ می دهد که نه تنها زحمات برنامه نویس را از بین می برد، بلکه باعث ضایع شدن شخصیت کاری وی می گردد. شاید اگر از همان اول برنامه نویس مدت زمان بیشتری را صرف نگارش، تست و بازبینی برنامه خود می کرد، ماندگاری برنامه بی نقص وی باعث افزایش اعتبار وی در محیط کاری می شد.</p><p><strong>من نبودم! عدم مسئولیت پذیری و عذرخواهی</strong><br /> برخی اوقات بخشی از برنامه دچار ایراد می شود و کسی عهده دار ایراد بوجود آمده نیست. از لحاظ اخلاقی گفتن یک عذرخواهی نه تنها از شخصیت شما نمی کاهد، بلکه نشاندهنده حس مسئولیت پذیری شما می شود. البته با نوشتن توضیحات (Comment) در برنامه می توانید، نویسنده کد را به راحتی بیابید.</p><p><strong>سرخوردگی از انجام کارهای تکراری</strong><br /> این مورد بارها برای من اتفاق افتاده است. بدترین بخش کار، انجام دادن مواردی است که هم سطحی هستند، هم حوصله می خواهند و هم از عهده افراد سطح پایین تر و دیگر بر می آیند. اما به هر حال مواردی پیش می آید که مجبور به انجام دادن این قبیل کارها هستید. بهترین راه حل حفظ آرامش و انجام دادن کار در اولین فرصت است. بعید می دانم راه حل دیگری پیدا شود.</p><p><strong>انجام دادن ناقص کارها</strong><br /> برخی از برنامه نویس ها، بخصوص کم تجربه تر ها، معنای صحیح اتمام کار را نمی دانند. یعنی انجام دادن کار را به معنی نگارش کد می دانند و مراحل مستندسازی، تست، ادغام کد در پروژه و&#8230; را در زمان لازم برای اتمام کار در نظر نمی گیرند. چه بسا پیدا شدن یک خطا در مرحله تست می تواند وی را ساعت ها درگیر کند.</p><p><strong>اعمال سلیقه شخصی</strong><br /> منظور از اعمال سلیقه شخصی عدم تفکر در هنگام برنامه نویسی نیست. بلکه مفهوم آن در نظر داشتن دیدگاه مشتری در اولویت بالاتر نسبت به دیدگاه شخصی است.</p><p>در صورتی که شما عادت بد دیگری را سراغ دارید، خوشحال می شوم آن را به اشتراک بگذارید.</p><p>منبع تصویر: <a href="http://www.worthlessgenius.com/2009/04/22/so-you-want-to-be-a-programmer/">worthlessgenius.com</a></p><p>شاد باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b9%25d8%25a7%25d8%25af%25d8%25aa-%25d9%2587%25d8%25a7%25db%258c-%25d8%25a8%25d8%25af-%25d8%25a8%25d8%25b1%25d9%2586%25d8%25a7%25d9%2585%25d9%2587-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25d8%25a7%25d9%2586%2F&amp;linkname=%D8%B9%D8%A7%D8%AF%D8%AA%20%D9%87%D8%A7%DB%8C%20%D8%A8%D8%AF%20%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87%20%D9%86%D9%88%DB%8C%D8%B3%D8%A7%D9%86" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b9%25d8%25a7%25d8%25af%25d8%25aa-%25d9%2587%25d8%25a7%25db%258c-%25d8%25a8%25d8%25af-%25d8%25a8%25d8%25b1%25d9%2586%25d8%25a7%25d9%2585%25d9%2587-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25d8%25a7%25d9%2586%2F&amp;linkname=%D8%B9%D8%A7%D8%AF%D8%AA%20%D9%87%D8%A7%DB%8C%20%D8%A8%D8%AF%20%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87%20%D9%86%D9%88%DB%8C%D8%B3%D8%A7%D9%86" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b9%25d8%25a7%25d8%25af%25d8%25aa-%25d9%2587%25d8%25a7%25db%258c-%25d8%25a8%25d8%25af-%25d8%25a8%25d8%25b1%25d9%2586%25d8%25a7%25d9%2585%25d9%2587-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25d8%25a7%25d9%2586%2F&amp;linkname=%D8%B9%D8%A7%D8%AF%D8%AA%20%D9%87%D8%A7%DB%8C%20%D8%A8%D8%AF%20%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87%20%D9%86%D9%88%DB%8C%D8%B3%D8%A7%D9%86" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b9%25d8%25a7%25d8%25af%25d8%25aa-%25d9%2587%25d8%25a7%25db%258c-%25d8%25a8%25d8%25af-%25d8%25a8%25d8%25b1%25d9%2586%25d8%25a7%25d9%2585%25d9%2587-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25d8%25a7%25d9%2586%2F&amp;linkname=%D8%B9%D8%A7%D8%AF%D8%AA%20%D9%87%D8%A7%DB%8C%20%D8%A8%D8%AF%20%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87%20%D9%86%D9%88%DB%8C%D8%B3%D8%A7%D9%86" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d8%25b9%25d8%25a7%25d8%25af%25d8%25aa-%25d9%2587%25d8%25a7%25db%258c-%25d8%25a8%25d8%25af-%25d8%25a8%25d8%25b1%25d9%2586%25d8%25a7%25d9%2585%25d9%2587-%25d9%2586%25d9%2588%25db%258c%25d8%25b3%25d8%25a7%25d9%2586%2F&amp;title=%D8%B9%D8%A7%D8%AF%D8%AA%20%D9%87%D8%A7%DB%8C%20%D8%A8%D8%AF%20%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87%20%D9%86%D9%88%DB%8C%D8%B3%D8%A7%D9%86" id="wpa2a_10">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%85%d8%b3%d8%a7%d9%81%d8%b1%d8%aa-%d8%a8%d9%85-%d9%88-devcheshmaknet/' rel='bookmark' title='مسافرت بم  و سفره برنامه نویسی من'>مسافرت بم  و سفره برنامه نویسی من</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%db%8c%d8%b3%db%8c/' rel='bookmark' title='برنامه نویسی'>برنامه نویسی</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-gconf-cleaner/' rel='bookmark' title='برنامه Gconf Cleaner'>برنامه Gconf Cleaner</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d8%b9%d8%a7%d8%af%d8%aa-%d9%87%d8%a7%db%8c-%d8%a8%d8%af-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%db%8c%d8%b3%d8%a7%d9%86/feed/</wfw:commentRss> <slash:comments>9</slash:comments> </item> <item><title>نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL</title><link>http://zebardast.ir/%d9%86%da%a9%d8%a7%d8%aa%db%8c-%d8%af%d8%b1-%d8%b2%d9%85%db%8c%d9%86%d9%87-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/</link> <comments>http://zebardast.ir/%d9%86%da%a9%d8%a7%d8%aa%db%8c-%d8%af%d8%b1-%d8%b2%d9%85%db%8c%d9%86%d9%87-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/#comments</comments> <pubDate>Sun, 13 Mar 2011 16:22:56 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[پایگاه داده MySQL]]></category> <category><![CDATA[مای‌اس‌کیوال]]></category> <category><![CDATA[پایگاه داده]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1351</guid> <description><![CDATA[سلام در طول چند سال کار با پایگاه داده MySQL تعدادی Tips (نکته یا راهنما) یاد گرفتم که کار با آن را برای من ساده تر می کردند. مطلب امروز تعدادی از این نکات را معرفی می کند. نمایش عمودی نتایج برای مشاهده عمومی نتایج یک query به جای ; از \G در انتهای آن [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%a7%d8%b2-%d9%81%d8%a7%db%8c%d9%84-%d8%a8%d9%87-mysql/' rel='bookmark' title='وارد کردن اطلاعات از فایل به پایگاه داده MySQL'>وارد کردن اطلاعات از فایل به پایگاه داده MySQL</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%a7%d8%b2%db%8c%d8%a7%d8%a8%db%8c-%d8%af%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql-%d9%82%d8%b3%d9%85%d8%aa-%d8%a7%d9%88%d9%84/' rel='bookmark' title='بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول'>بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول</a></li><li><a href='http://zebardast.ir/%d8%a7%d9%86%d9%88%d8%a7%d8%b9-%d8%af%d8%a7%d8%af%d9%87-%d9%87%d8%a7-%d8%af%d8%b1-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/' rel='bookmark' title='انواع داده در MySQL'>انواع داده در MySQL</a></li></ol>]]></description> <content:encoded><![CDATA[<p>سلام <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p>در طول چند سال کار با پایگاه داده MySQL تعدادی Tips (نکته یا راهنما) یاد گرفتم که کار با آن را برای من ساده تر می کردند. مطلب امروز تعدادی از این نکات را معرفی می کند.</p><p><strong>نمایش عمودی نتایج</strong><br /> برای مشاهده عمومی نتایج یک query به جای ; از <code>\G</code> در انتهای آن استفاده کنید. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; select * from PARTITIONS limit 2 \G
*************************** 1. row ***************************
                TABLE_CATALOG: NULL
                 TABLE_SCHEMA: information_schema
                   TABLE_NAME: CHARACTER_SETS
               PARTITION_NAME: NULL
            SUBPARTITION_NAME: NULL
   PARTITION_ORDINAL_POSITION: NULL
SUBPARTITION_ORDINAL_POSITION: NULL
             PARTITION_METHOD: NULL
          SUBPARTITION_METHOD: NULL
         PARTITION_EXPRESSION: NULL
      SUBPARTITION_EXPRESSION: NULL
        PARTITION_DESCRIPTION: NULL
                   TABLE_ROWS: 0
               AVG_ROW_LENGTH: 384
                  DATA_LENGTH: 0
              MAX_DATA_LENGTH: 16604160
                 INDEX_LENGTH: 0
                    DATA_FREE: 0
                  CREATE_TIME: NULL
                  UPDATE_TIME: NULL
                   CHECK_TIME: NULL
                     CHECKSUM: NULL
            PARTITION_COMMENT:
                    NODEGROUP:
              TABLESPACE_NAME: NULL
*************************** 2. row ***************************
                TABLE_CATALOG: NULL
                 TABLE_SCHEMA: information_schema
                   TABLE_NAME: COLLATIONS
               PARTITION_NAME: NULL
            SUBPARTITION_NAME: NULL
   PARTITION_ORDINAL_POSITION: NULL
SUBPARTITION_ORDINAL_POSITION: NULL
             PARTITION_METHOD: NULL
          SUBPARTITION_METHOD: NULL
         PARTITION_EXPRESSION: NULL
      SUBPARTITION_EXPRESSION: NULL
        PARTITION_DESCRIPTION: NULL
                   TABLE_ROWS: 0
               AVG_ROW_LENGTH: 231
                  DATA_LENGTH: 0
              MAX_DATA_LENGTH: 16704765
                 INDEX_LENGTH: 0
                    DATA_FREE: 0
                  CREATE_TIME: NULL
                  UPDATE_TIME: NULL
                   CHECK_TIME: NULL
                     CHECKSUM: NULL
            PARTITION_COMMENT:
                    NODEGROUP:
              TABLESPACE_NAME: NULL
</pre><p><strong>استفاده از <code>--safe-updates</code></strong><br /> با استفاده از پارامتر <code>--safe-updates</code> (:معادل <code>--i-am-a-dummy</code> یا <code>-U</code>) می توانید یک حصار امنیتی برای query های مربوط به update و delete فعال کنید. بدین صورت که اگر query حذف یا ویرایش شما where نداشته باشد، اجرا نمی شود. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; delete from meta;
ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column
</pre><p>یا</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; update meta set meta_key = 'my_key';
ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column
</pre><p>همچنین شما می توانید به جای استفاده از پارامتر <code>--safe-updates</code> از دستور SET در MySQL استفاده نمایید. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; SET sql_safe_updates=1, sql_select_limit=1000, sql_max_join_size=1000000;
</pre><p>دستور بالا علاوه بر فعال کردن safe updates ، حداکثرهایی نیز برای محدودیت select ساده و انتخاب چندین جدولی اعمال می کند.</p><p><strong>فعال سازی auto complete و بروزرسانی cache آن</strong><br /> بعد از نصب MySQL در بسیاری از موارد قابلیت auto complete یا همان «کامل کردن خودکار» فعال است. پارامتر مربوط به فعال سازی آن <code>--auto-rehash</code> می باشد. همچنین شما می توانید در خط فرمان MySQL با تایپ <code>\#</code> این قابلیت را فعال کنید. کاربرد دیگر <code>\#</code> بروزرسانی کش auto completion بعد از انجام تغییرات بر روی پایگاه داده می باشد.<br /> *برای کامل کردن یک خط کافیست دکمه Tab را فشار دهید. در صورتی که نتایج برای کامل کردن یک عبارت بیش از یک مورد باشد، با زدن دو tab پشت سر هم، فهرست این نتایج را مشاهده می فرمایید.</p><p><strong>مشاهده فهرست کامل فرایندهای در حال اجرا</strong><br /> برای مشاهده فرایندهای در حال اجرا کافیست دستور show processlist را در خط فرمان وارد کنید. همچنین برای نمایش کامل query در حال اجرا می توانید پارامتر full را به این دستور اضافه کنید. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; show full processlist;
+------+------+-----------+---------+---------+------+-------+-----------------------+
| Id   | User | Host      | db      | Command | Time | State | Info                  |
+------+------+-----------+---------+---------+------+-------+-----------------------+
| 3101 | root | localhost | efs_tmp | Query   |    0 | NULL  | show full processlist |
+------+------+-----------+---------+---------+------+-------+-----------------------+
</pre><p><strong>کشتن (kill) یک فرایند</strong><br /> در ستون اول خروجی دستور show processlist آی دی مربوط به فرآیند در حال اجرا را مشاهده کردید. برای متوقف ساختن این فرایند کافیست دستور kill را به صورت زیر اجرا کنیم:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; kill 3101;
</pre><p><strong>مشاهده وضعیت MySQL و برخی اطلاعات بیشتر</strong><br /> برای مشاهده وضعیت کلی MySQL شامل تنظیمات و پارامتر های فعال شده از دستور show status استفاده می کنیم. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; show status;
+-----------------------------------+-----------+
| Variable_name                     | Value     |
+-----------------------------------+-----------+
| Aborted_clients                   | 3         |
| Aborted_connects                  | 0         |
| Binlog_cache_disk_use             | 0         |
| Binlog_cache_use                  | 0         |
| Bytes_received                    | 1346      |
..........
........
......
...
.
</pre><p>همچنین برای مشاهده وضعیت INNODB از دستور SHOW ENGINE INNODB STATUS استفاده نمایید.<br /> دستور show table status نیز برای مشاهده وضعیت جداول استفاده می شود. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; show table status like '%user%' \G
*************************** 1. row ***************************
           Name: user
         Engine: MyISAM
        Version: 10
     Row_format: Dynamic
           Rows: 14
 Avg_row_length: 80
    Data_length: 1128
Max_data_length: 281474976710655
   Index_length: 2048
      Data_free: 0
 Auto_increment: NULL
    Create_time: 2010-11-21 18:07:11
    Update_time: 2011-02-27 14:57:28
     Check_time: NULL
      Collation: utf8_bin
       Checksum: NULL
 Create_options:
        Comment: Users and global privileges
1 row in set (0.00 sec)
</pre><p>* از like برای محدود ساختن نتایج استفاده کرده ام.</p><p><strong>دسترسی سریع به وضعیت پایگاه داده</strong><br /> برای دسترسی سریع به پایگاه داده کافیست دستور <code>\s</code> را در خط فرمان MySQL وارد نمایید:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; \s
--------------
mysql  Ver 14.14 Distrib 5.1.49, for debian-linux-gnu (i686) using readline 6.1

Connection id:		3103
Current database:	mydb_tmp
Current user:		root@localhost
SSL:			Not in use
Current pager:		stdout
Using outfile:		''
Using delimiter:	;
Server version:		5.1.49-1ubuntu8.1 (Ubuntu)
Protocol version:	10
Connection:		Localhost via UNIX socket
Server characterset:	utf8
Db     characterset:	utf8
Client characterset:	latin1
Conn.  characterset:	latin1
UNIX socket:		/var/run/mysqld/mysqld.sock
Uptime:			12 hours 39 min 28 sec

Threads: 1  Questions: 27846  Slow queries: 2  Opens: 7711  Flush tables: 1  Open tables: 64  Queries per second avg: 0.611
--------------
</pre><p><strong>دستور show create</strong><br /> به طور کلی دستور show create برای مشاهده نحوه ساخت یک جدول، پایگاه داده، تابع و&#8230; استفاده می شود. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; show create database mysql \G
*************************** 1. row ***************************
       Database: mysql
Create Database: CREATE DATABASE `mysql` /*!40100 DEFAULT CHARACTER SET utf8 */
</pre><p>یا</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; show create table time_zone \G
*************************** 1. row ***************************
       Table: time_zone
Create Table: CREATE TABLE `time_zone` (
  `Time_zone_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `Use_leap_seconds` enum('Y','N') NOT NULL DEFAULT 'N',
  PRIMARY KEY (`Time_zone_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='Time zones'
</pre><p><strong>ساخت یک جدول از ترکیب چند جدول</strong><br /> یکی از انواع engine های موجود در MySQL انجین <a href="http://dev.mysql.com/doc/refman/5.0/en/merge-storage-engine.html">MERGE</a> یا MRG_MyISAM می باشد. این engine برای ترکیب چندین جدول در یک جدول مورد استفاده قرار می گیرد.<br /> در زیر ما دو جدول با انجین MyISAM و یک جدول total با انجین MERGE از ترکیب دو جدول اول ساخته ایم:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; CREATE TABLE t1 (
    -&gt;    a INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
    -&gt;    message CHAR(20)) ENGINE=MyISAM;
mysql&gt; CREATE TABLE t2 (
    -&gt;    a INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
    -&gt;    message CHAR(20)) ENGINE=MyISAM;
mysql&gt; CREATE TABLE total (
    -&gt;    a INT NOT NULL AUTO_INCREMENT,
    -&gt;    message CHAR(20), INDEX(a))
    -&gt;    ENGINE=MERGE UNION=(t1,t2) INSERT_METHOD=LAST;
</pre><p>در صورت وارد کردن اطلاعات به t1 و t ویا بروزرسانی اطلاعات آن ها، امکان دستیابی به اطلاعات از طریق جدول total وجود دارد. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; INSERT INTO t1 (message) VALUES ('Testing'),('table'),('t1');
mysql&gt; INSERT INTO t2 (message) VALUES ('Testing'),('table'),('t2');

mysql&gt; SELECT * FROM total;
+---+---------+
| a | message |
+---+---------+
| 1 | Testing |
| 2 | table   |
| 3 | t1      |
| 1 | Testing |
| 2 | table   |
| 3 | t2      |
+---+---------+
</pre><p><strong>دستور mysqlshow برای دسترسی سریع به فهرست اطلاعات</strong><br /> شما می توانید برای دسترسی سریع به فهرست پایگاه های داده، جداول و ستون های آنها از دستور mysqlshow استفاده نمایید. مانند:</p><pre class="brush: sql; title: ; notranslate">$ mysqlshow -uroot
+--------------------+
|     Databases      |
+--------------------+
| information_schema |
| mydb_tmp            |
| mydb               |
| mysql              |
| radius             |
| security           |
+--------------------+
</pre><p>یا</p><pre class="brush: sql; title: ; notranslate">$ mysqlshow -uroot mysql
Database: mysql
+---------------------------+
|          Tables           |
+---------------------------+
| columns_priv              |
| db                        |
| event                     |
| func                      |
| general_log               |
| help_category             |
| help_keyword              |
| help_relation             |
| help_topic                |
| host                      |
| ndb_binlog_index          |
| plugin                    |
| proc                      |
| procs_priv                |
| servers                   |
| slow_log                  |
| tables_priv               |
| time_zone                 |
| time_zone_leap_second     |
| time_zone_name            |
| time_zone_transition      |
| time_zone_transition_type |
| user                      |
+---------------------------+
</pre><p>یا</p><pre class="brush: sql; title: ; notranslate">$ mysqlshow -uroot mysql servers
Database: mysql  Table: servers
+-------------+----------+-----------------+------+-----+---------+-------+---------------------------------+---------+
| Field       | Type     | Collation       | Null | Key | Default | Extra | Privileges                      | Comment |
+-------------+----------+-----------------+------+-----+---------+-------+---------------------------------+---------+
| Server_name | char(64) | utf8_general_ci | NO   | PRI |         |       | select,insert,update,references |         |
| Host        | char(64) | utf8_general_ci | NO   |     |         |       | select,insert,update,references |         |
| Db          | char(64) | utf8_general_ci | NO   |     |         |       | select,insert,update,references |         |
| Username    | char(64) | utf8_general_ci | NO   |     |         |       | select,insert,update,references |         |
| Password    | char(64) | utf8_general_ci | NO   |     |         |       | select,insert,update,references |         |
| Port        | int(4)   |                 | NO   |     | 0       |       | select,insert,update,references |         |
| Socket      | char(64) | utf8_general_ci | NO   |     |         |       | select,insert,update,references |         |
| Wrapper     | char(64) | utf8_general_ci | NO   |     |         |       | select,insert,update,references |         |
| Owner       | char(64) | utf8_general_ci | NO   |     |         |       | select,insert,update,references |         |
+-------------+----------+-----------------+------+-----+---------+-------+---------------------------------+---------+
</pre><p><strong>مرتب سازی همراه با ارجحیت</strong><br /> در صورتی که قصد دارید علاوه بر مرتب سازی یک query انتخاب، ارجحیتی نیز به بعضی از ریف های آن بدهید، کافیست از ترکیب <code>IN()</code> و order by استفاده کنید. در مثال زیر علاوه بر مرتب سازی بر اساس ستون iso_code به ردیف های IR و US ارجحیت و وزن بالاتری داده ایم:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt;SELECT * FROM countries ORDER by iso_code IN ('IR', 'US') desc;
+----------+----------------------------------------+
| iso_code | name                                   |
+----------+----------------------------------------+
| IR       | IRAN                         |
| US       | United States                          |
| AF       | Afghanistan                            |
| AL       | Albania                                |
| DZ       | Algeria                                |
| AS       | American Samoa                         |
+----------+----------------------------------------+
</pre><p>امیدوارم که این مطلب راهنمای خوبی برای استفاده راحت تر و مفید تر از پایگاه داده MySQL باشد.</p><p>موفق باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_cool.gif' alt='8)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2586%25da%25a9%25d8%25a7%25d8%25aa%25db%258c-%25d8%25af%25d8%25b1-%25d8%25b2%25d9%2585%25db%258c%25d9%2586%25d9%2587-%25d8%25a7%25d8%25b3%25d8%25aa%25d9%2581%25d8%25a7%25d8%25af%25d9%2587-%25d8%25a7%25d8%25b2-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D9%86%DA%A9%D8%A7%D8%AA%DB%8C%20%D8%AF%D8%B1%20%D8%B2%D9%85%DB%8C%D9%86%D9%87%20%D8%A7%D8%B3%D8%AA%D9%81%D8%A7%D8%AF%D9%87%20%D8%B1%D8%A7%D8%AD%D8%AA%20%D8%AA%D8%B1%20%D8%A7%D8%B2%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2586%25da%25a9%25d8%25a7%25d8%25aa%25db%258c-%25d8%25af%25d8%25b1-%25d8%25b2%25d9%2585%25db%258c%25d9%2586%25d9%2587-%25d8%25a7%25d8%25b3%25d8%25aa%25d9%2581%25d8%25a7%25d8%25af%25d9%2587-%25d8%25a7%25d8%25b2-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D9%86%DA%A9%D8%A7%D8%AA%DB%8C%20%D8%AF%D8%B1%20%D8%B2%D9%85%DB%8C%D9%86%D9%87%20%D8%A7%D8%B3%D8%AA%D9%81%D8%A7%D8%AF%D9%87%20%D8%B1%D8%A7%D8%AD%D8%AA%20%D8%AA%D8%B1%20%D8%A7%D8%B2%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2586%25da%25a9%25d8%25a7%25d8%25aa%25db%258c-%25d8%25af%25d8%25b1-%25d8%25b2%25d9%2585%25db%258c%25d9%2586%25d9%2587-%25d8%25a7%25d8%25b3%25d8%25aa%25d9%2581%25d8%25a7%25d8%25af%25d9%2587-%25d8%25a7%25d8%25b2-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D9%86%DA%A9%D8%A7%D8%AA%DB%8C%20%D8%AF%D8%B1%20%D8%B2%D9%85%DB%8C%D9%86%D9%87%20%D8%A7%D8%B3%D8%AA%D9%81%D8%A7%D8%AF%D9%87%20%D8%B1%D8%A7%D8%AD%D8%AA%20%D8%AA%D8%B1%20%D8%A7%D8%B2%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2586%25da%25a9%25d8%25a7%25d8%25aa%25db%258c-%25d8%25af%25d8%25b1-%25d8%25b2%25d9%2585%25db%258c%25d9%2586%25d9%2587-%25d8%25a7%25d8%25b3%25d8%25aa%25d9%2581%25d8%25a7%25d8%25af%25d9%2587-%25d8%25a7%25d8%25b2-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;linkname=%D9%86%DA%A9%D8%A7%D8%AA%DB%8C%20%D8%AF%D8%B1%20%D8%B2%D9%85%DB%8C%D9%86%D9%87%20%D8%A7%D8%B3%D8%AA%D9%81%D8%A7%D8%AF%D9%87%20%D8%B1%D8%A7%D8%AD%D8%AA%20%D8%AA%D8%B1%20%D8%A7%D8%B2%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d9%2586%25da%25a9%25d8%25a7%25d8%25aa%25db%258c-%25d8%25af%25d8%25b1-%25d8%25b2%25d9%2585%25db%258c%25d9%2586%25d9%2587-%25d8%25a7%25d8%25b3%25d8%25aa%25d9%2581%25d8%25a7%25d8%25af%25d9%2587-%25d8%25a7%25d8%25b2-%25d9%25be%25d8%25a7%25db%258c%25da%25af%25d8%25a7%25d9%2587-%25d8%25af%25d8%25a7%25d8%25af%25d9%2587-mysql%2F&amp;title=%D9%86%DA%A9%D8%A7%D8%AA%DB%8C%20%D8%AF%D8%B1%20%D8%B2%D9%85%DB%8C%D9%86%D9%87%20%D8%A7%D8%B3%D8%AA%D9%81%D8%A7%D8%AF%D9%87%20%D8%B1%D8%A7%D8%AD%D8%AA%20%D8%AA%D8%B1%20%D8%A7%D8%B2%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" id="wpa2a_12">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%a7%d8%b2-%d9%81%d8%a7%db%8c%d9%84-%d8%a8%d9%87-mysql/' rel='bookmark' title='وارد کردن اطلاعات از فایل به پایگاه داده MySQL'>وارد کردن اطلاعات از فایل به پایگاه داده MySQL</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%a7%d8%b2%db%8c%d8%a7%d8%a8%db%8c-%d8%af%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql-%d9%82%d8%b3%d9%85%d8%aa-%d8%a7%d9%88%d9%84/' rel='bookmark' title='بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول'>بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول</a></li><li><a href='http://zebardast.ir/%d8%a7%d9%86%d9%88%d8%a7%d8%b9-%d8%af%d8%a7%d8%af%d9%87-%d9%87%d8%a7-%d8%af%d8%b1-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/' rel='bookmark' title='انواع داده در MySQL'>انواع داده در MySQL</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d9%86%da%a9%d8%a7%d8%aa%db%8c-%d8%af%d8%b1-%d8%b2%d9%85%db%8c%d9%86%d9%87-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/feed/</wfw:commentRss> <slash:comments>4</slash:comments> </item> <item><title>بدست آوردن کشور یک آدرس IP به کمک MySQL</title><link>http://zebardast.ir/%d8%a8%d8%af%d8%b3%d8%aa-%d8%a2%d9%88%d8%b1%d8%af%d9%86-%da%a9%d8%b4%d9%88%d8%b1-%db%8c%da%a9-%d8%a2%d8%af%d8%b1%d8%b3-ip-%d8%a8%d9%87-%da%a9%d9%85%da%a9-mysql/</link> <comments>http://zebardast.ir/%d8%a8%d8%af%d8%b3%d8%aa-%d8%a2%d9%88%d8%b1%d8%af%d9%86-%da%a9%d8%b4%d9%88%d8%b1-%db%8c%da%a9-%d8%a2%d8%af%d8%b1%d8%b3-ip-%d8%a8%d9%87-%da%a9%d9%85%da%a9-mysql/#comments</comments> <pubDate>Sat, 26 Feb 2011 12:56:10 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[برنامه نویسی]]></category> <category><![CDATA[پایگاه داده MySQL]]></category> <category><![CDATA[IP]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1339</guid> <description><![CDATA[سلام مطلب امروز روشی برای بدست آوردن کشور یک آدرس IP (بخوانید آی پی) با استفاده از پایگاه داده MySQL را آموزش می دهد. در این مطلب ابتدا یک جدول که حاوی نام کشور و محدوده IP های آن می باشد ایجاد می کنیم. سپس با تعریف یک تابع، امکان تشخیص سریع کشور مرتبط با [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/mysql_last_insert_id/' rel='bookmark' title='روش بدست آوردن آخرین آی دی ثبت شده در دیتابیس &#8211; MySQL'>روش بدست آوردن آخرین آی دی ثبت شده در دیتابیس &#8211; MySQL</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%a7%d8%b2%db%8c%d8%a7%d8%a8%db%8c-%d8%af%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql-%d9%82%d8%b3%d9%85%d8%aa-%d8%a7%d9%88%d9%84/' rel='bookmark' title='بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول'>بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول</a></li><li><a href='http://zebardast.ir/%da%86%da%af%d9%88%d9%86%da%af%db%8c-%d8%a8%d8%af%d8%b3%d8%aa-%d8%a2%d9%88%d8%b1%d8%af%d9%86-%d9%84%db%8c%d8%b3%d8%aa-%d8%a8%d8%b3%d8%aa%d9%87-%d9%87%d8%a7%db%8c-%d9%86%d8%b1%d9%85-%d8%a7%d9%81%d8%b2/' rel='bookmark' title='چگونگی بدست آوردن لیست بسته های نرم افزاری که بیشتری فضا را استفاده کرده اند'>چگونگی بدست آوردن لیست بسته های نرم افزاری که بیشتری فضا را استفاده کرده اند</a></li></ol>]]></description> <content:encoded><![CDATA[<p>سلام <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p>مطلب امروز روشی برای بدست آوردن کشور یک آدرس IP (بخوانید آی پی) با استفاده از پایگاه داده MySQL را آموزش می دهد. در این مطلب ابتدا یک جدول که حاوی نام کشور و محدوده IP های آن می باشد ایجاد می کنیم. سپس با تعریف یک تابع، امکان تشخیص سریع کشور مرتبط با هر آی پی را ارائه می دهیم.</p><h3>IP چیست؟</h3><p>به نقل از صفحه «<a href="http://fa.wikipedia.org/wiki/%D9%86%D8%B4%D8%A7%D9%86%DB%8C_%D9%BE%D8%B1%D9%88%D8%AA%DA%A9%D9%84_%D8%A7%DB%8C%D9%86%D8%AA%D8%B1%D9%86%D8%AA">نشانی پروتکل اینترنت</a>» در ویکی پدیا، دانشنامه آزاد:</p><blockquote><p> نشانی پروتکل اینترنت (Internet Protocol Address) یا به اختصار نشانی آی‌پی (IP Address) نشانی‌ عددی است که به هریک از دستگاه ها و رایانه‌های متصل به شبکه ی رایانه ای که بر مبنای نمایه TCP/IP (از جمله اینترنت) کار می‌کند، اختصاص داده می‌شوند. پیام‌هایی که دیگر رایانه‌ها برای این رایانه می‌فرستند با این نشانه ی عددی همراه است و راه یاب های شبکه آن را مانند «نشانی گیرنده» در نامه‌های پستی تعبیر می‌کنند، تا بالاخره پیام به رابط شبکه رایانه مورد نظر برسد.</p></blockquote><h3>جدول پایگاه داده</h3><p>من اطلاعات مربوط به محدوده آدرس های آی پی و کشور مرتبط با آنها در جدولی با نام ip_location ذخیره کرده ام. برای ایجاد این جدول دستور زیر را در خط فرمان MySQL وارد نمایید:</p><pre class="brush: sql; title: ; notranslate">
CREATE TABLE `ip_location` (
  `from_ip` int(15) DEFAULT NULL,
  `to_ip` int(15) DEFAULT NULL,
  `country` varchar(32) DEFAULT NULL,
  KEY `from_ip` (`from_ip`,`country`),
  KEY `to_ip` (`to_ip`,`country`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
</pre><p>مرحله بعد وارد کردن فهرست کشورها و محدوده آی پی های آن هاست. برای سادگی کار من یک خروجی (Dump) از دستور ایجاد جدول ip_location و اطلاعات موجود در آن تهیه کرده ام.<br /> • <a href='http://zebardast.ir/wp-content/uploads/2011/02/ip_location.sql_.zip'>دریافت ip_location.sql</a> با حجم 165KB<br /> در صورتی که آشنایی با وارد کردن (import) چنین فایل هایی ندارید، پیشنهاد می کنم مطلب «<a href="http://zebardast.ir/%D8%B1%D8%A7%D9%87%D9%86%D9%85%D8%A7%DB%8C-%D9%88%D8%A7%D8%B1%D8%AF-%DA%A9%D8%B1%D8%AF%D9%86import-%D9%88-%D8%B5%D8%A7%D8%AF%D8%B1-%DA%A9%D8%B1%D8%AF%D9%86export-%D8%AF%D8%B1-mysql/">راهنمای وارد کردن(import) و صادر کردن(export) در MySQL</a>» را مطالعه کنید.</p><h3>تابع getIpCountry</h3><p>مرحله بعد تعریف تابعی برای محاسبه آدرس ۳۲ بیتی هر آی پی و مقایسه آن با محدوده های موجود در جدول ip_location است. برای تعریف این تابع دستورات زیر را در خط فرمان MySQL وارد کنید:</p><pre class="brush: sql; title: ; notranslate">
DELIMITER $$
CREATE FUNCTION getIpCountry(ip varchar(15)) RETURNS varchar(64)
BEGIN
 declare a tinyint unsigned;
 declare b tinyint unsigned;
 declare c tinyint unsigned;
 declare d tinyint unsigned;
 declare total bigint;
 declare result varchar(64);
 select substring_index(ip, '.', 1 ) into a;
 select substring_index(substring_index(ip , '.', 2 ),'.',-1) into b;
 select substring_index(substring_index(ip , '.', -2 ),'.',1) into c;
 select substring_index(ip, '.', -1 ) into d;
 set total := (a*256*256*256) + (b*256*256) + (c*256) + d;
 select SQL_CACHE country into result from ip_location where total between from_ip and to_ip limit 1;
 if (result is null) or (result = '') then
 set result := 'unknown';
 end if;
 return result;
 END$$
DELIMITER ;
</pre><h3>بدست آوردن کشور</h3><p>برای مشاهده کشور مرتبط با هر آی پی کافیست تا با استفاده از دستور SELECT تابع getIpCountry را فراخوانی نماییم. مانند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; SELECT getIpCountry('79.175.165.171');
+--------------------------------+
| getIpCountry('79.175.165.171') |
+--------------------------------+
| IRAN (ISLAMIC REPUBLIC OF)     |
+--------------------------------+
1 row in set (0.03 sec)

mysql&gt; SELECT getIpCountry('4.2.2.4');
+-------------------------+
| getIpCountry('4.2.2.4') |
+-------------------------+
| UNITED STATES           |
+-------------------------+
1 row in set (0.00 sec)
</pre><h3>ایده استفاده</h3><p>فرض کنید که شما سایتی به دو زبان فارسی و انگلیسی دارید. با استفاده از این روش امکان تشخیص کشور بازدیدکننده برای شما بوجود می آید. در نتیجه می توانید کاربر بیننده را به صورت پیش فرض به سایت انگلیسی یا فارسی خود راهنمایی کنید. این روش قابل تعمیم به چندین زبان می باشد.</p><h3>پی نوشت</h3><p>• این مطلب فقط برای آدرس های آی پی نسخه ۴ قابل استفاده است.</p><p>موفق باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_cool.gif' alt='8)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a8%25d8%25af%25d8%25b3%25d8%25aa-%25d8%25a2%25d9%2588%25d8%25b1%25d8%25af%25d9%2586-%25da%25a9%25d8%25b4%25d9%2588%25d8%25b1-%25db%258c%25da%25a9-%25d8%25a2%25d8%25af%25d8%25b1%25d8%25b3-ip-%25d8%25a8%25d9%2587-%25da%25a9%25d9%2585%25da%25a9-mysql%2F&amp;linkname=%D8%A8%D8%AF%D8%B3%D8%AA%20%D8%A2%D9%88%D8%B1%D8%AF%D9%86%20%DA%A9%D8%B4%D9%88%D8%B1%20%DB%8C%DA%A9%20%D8%A2%D8%AF%D8%B1%D8%B3%20IP%20%D8%A8%D9%87%20%DA%A9%D9%85%DA%A9%20MySQL" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a8%25d8%25af%25d8%25b3%25d8%25aa-%25d8%25a2%25d9%2588%25d8%25b1%25d8%25af%25d9%2586-%25da%25a9%25d8%25b4%25d9%2588%25d8%25b1-%25db%258c%25da%25a9-%25d8%25a2%25d8%25af%25d8%25b1%25d8%25b3-ip-%25d8%25a8%25d9%2587-%25da%25a9%25d9%2585%25da%25a9-mysql%2F&amp;linkname=%D8%A8%D8%AF%D8%B3%D8%AA%20%D8%A2%D9%88%D8%B1%D8%AF%D9%86%20%DA%A9%D8%B4%D9%88%D8%B1%20%DB%8C%DA%A9%20%D8%A2%D8%AF%D8%B1%D8%B3%20IP%20%D8%A8%D9%87%20%DA%A9%D9%85%DA%A9%20MySQL" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a8%25d8%25af%25d8%25b3%25d8%25aa-%25d8%25a2%25d9%2588%25d8%25b1%25d8%25af%25d9%2586-%25da%25a9%25d8%25b4%25d9%2588%25d8%25b1-%25db%258c%25da%25a9-%25d8%25a2%25d8%25af%25d8%25b1%25d8%25b3-ip-%25d8%25a8%25d9%2587-%25da%25a9%25d9%2585%25da%25a9-mysql%2F&amp;linkname=%D8%A8%D8%AF%D8%B3%D8%AA%20%D8%A2%D9%88%D8%B1%D8%AF%D9%86%20%DA%A9%D8%B4%D9%88%D8%B1%20%DB%8C%DA%A9%20%D8%A2%D8%AF%D8%B1%D8%B3%20IP%20%D8%A8%D9%87%20%DA%A9%D9%85%DA%A9%20MySQL" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25a8%25d8%25af%25d8%25b3%25d8%25aa-%25d8%25a2%25d9%2588%25d8%25b1%25d8%25af%25d9%2586-%25da%25a9%25d8%25b4%25d9%2588%25d8%25b1-%25db%258c%25da%25a9-%25d8%25a2%25d8%25af%25d8%25b1%25d8%25b3-ip-%25d8%25a8%25d9%2587-%25da%25a9%25d9%2585%25da%25a9-mysql%2F&amp;linkname=%D8%A8%D8%AF%D8%B3%D8%AA%20%D8%A2%D9%88%D8%B1%D8%AF%D9%86%20%DA%A9%D8%B4%D9%88%D8%B1%20%DB%8C%DA%A9%20%D8%A2%D8%AF%D8%B1%D8%B3%20IP%20%D8%A8%D9%87%20%DA%A9%D9%85%DA%A9%20MySQL" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d8%25a8%25d8%25af%25d8%25b3%25d8%25aa-%25d8%25a2%25d9%2588%25d8%25b1%25d8%25af%25d9%2586-%25da%25a9%25d8%25b4%25d9%2588%25d8%25b1-%25db%258c%25da%25a9-%25d8%25a2%25d8%25af%25d8%25b1%25d8%25b3-ip-%25d8%25a8%25d9%2587-%25da%25a9%25d9%2585%25da%25a9-mysql%2F&amp;title=%D8%A8%D8%AF%D8%B3%D8%AA%20%D8%A2%D9%88%D8%B1%D8%AF%D9%86%20%DA%A9%D8%B4%D9%88%D8%B1%20%DB%8C%DA%A9%20%D8%A2%D8%AF%D8%B1%D8%B3%20IP%20%D8%A8%D9%87%20%DA%A9%D9%85%DA%A9%20MySQL" id="wpa2a_14">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/mysql_last_insert_id/' rel='bookmark' title='روش بدست آوردن آخرین آی دی ثبت شده در دیتابیس &#8211; MySQL'>روش بدست آوردن آخرین آی دی ثبت شده در دیتابیس &#8211; MySQL</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%a7%d8%b2%db%8c%d8%a7%d8%a8%db%8c-%d8%af%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql-%d9%82%d8%b3%d9%85%d8%aa-%d8%a7%d9%88%d9%84/' rel='bookmark' title='بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول'>بازیابی داده از پایگاه داده MySQL &#8211; قسمت اول</a></li><li><a href='http://zebardast.ir/%da%86%da%af%d9%88%d9%86%da%af%db%8c-%d8%a8%d8%af%d8%b3%d8%aa-%d8%a2%d9%88%d8%b1%d8%af%d9%86-%d9%84%db%8c%d8%b3%d8%aa-%d8%a8%d8%b3%d8%aa%d9%87-%d9%87%d8%a7%db%8c-%d9%86%d8%b1%d9%85-%d8%a7%d9%81%d8%b2/' rel='bookmark' title='چگونگی بدست آوردن لیست بسته های نرم افزاری که بیشتری فضا را استفاده کرده اند'>چگونگی بدست آوردن لیست بسته های نرم افزاری که بیشتری فضا را استفاده کرده اند</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d8%a8%d8%af%d8%b3%d8%aa-%d8%a2%d9%88%d8%b1%d8%af%d9%86-%da%a9%d8%b4%d9%88%d8%b1-%db%8c%da%a9-%d8%a2%d8%af%d8%b1%d8%b3-ip-%d8%a8%d9%87-%da%a9%d9%85%da%a9-mysql/feed/</wfw:commentRss> <slash:comments>3</slash:comments> </item> <item><title>شروع کار با Google Maps API</title><link>http://zebardast.ir/%d8%b4%d8%b1%d9%88%d8%b9-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-google-maps-api/</link> <comments>http://zebardast.ir/%d8%b4%d8%b1%d9%88%d8%b9-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-google-maps-api/#comments</comments> <pubDate>Sun, 09 Jan 2011 08:08:59 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[جاوا اسکریپت]]></category> <category><![CDATA[نقشه]]></category> <category><![CDATA[گوگل]]></category> <category><![CDATA[گوگل مپ]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1229</guid> <description><![CDATA[سلام خیلی از ما با سرویس نقشه های گوگل (Google Maps) آشنا هستیم. این سرویس در ویکی پدیا اینگونه تعریف شده است: گوگل مپس (به انگلیسی: Google Maps، به معنی: نقشه‌های گوگل) یک محصول وب از شرکت گوگل است. در گوگل مپس، نقشه‌های دقیق و کاملی از زمین ارائه می‌گردد. گوگل مپس از فن‌آوری‌هایی چون [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/google-ajax-search-api/' rel='bookmark' title='Google AJAX Search API، یک موتور جستجو در وبلاگ شما'>Google AJAX Search API، یک موتور جستجو در وبلاگ شما</a></li><li><a href='http://zebardast.ir/google-apps-for-your-domain/' rel='bookmark' title='Google Apps for Your Domain'>Google Apps for Your Domain</a></li><li><a href='http://zebardast.ir/%d8%b3%d8%a7%d8%ae%d8%aa-%d9%85%d9%88%d8%aa%d9%88%d8%b1-%d8%ac%d8%b3%d8%aa%d8%ac%d9%88%db%8c-%d8%b4%d8%ae%d8%b5%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-google-co-op/' rel='bookmark' title='ساخت موتور جستجوی شخصی با استفاده از Google Co-op'>ساخت موتور جستجوی شخصی با استفاده از Google Co-op</a></li></ol>]]></description> <content:encoded><![CDATA[<p>سلام <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /><br /> خیلی از ما با سرویس نقشه های گوگل (Google Maps) آشنا هستیم. این سرویس در <a href="https://secure.wikimedia.org/wikipedia/fa/wiki/%DA%AF%D9%88%DA%AF%D9%84_%D9%85%D9%BE%D8%B3">ویکی پدیا</a> اینگونه تعریف شده است:</p><blockquote><p>گوگل مپس (به انگلیسی: Google Maps، به معنی: نقشه‌های گوگل) یک محصول وب از شرکت گوگل است. در گوگل مپس، نقشه‌های دقیق و کاملی از زمین ارائه می‌گردد. گوگل مپس از فن‌آوری‌هایی چون Tele Atlas استفاده می‌کند.</p></blockquote><p>گوگل مپس این امکان را برای مدیران و برنامه نویسان وب سایت ها فراهم کرده است تا با استفاده از <a href="https://code.google.com/apis/maps/"><abbr title="رابط برنامه‌نویسی نرم‌افزار - Application Programming Interface ">API</abbr> آن</a>، نقشه های موجود را به دلخواه در وب سایت خود نمایش دهند. در حال حاضر، گوگل رابط های زیر را ارائه می کند:</p><div class="ltr"><ul><li><a href="https://code.google.com/apis/maps/documentation/javascript/">Maps JavaScript API</a></li><li><a href="https://code.google.com/apis/maps/documentation/flash/">Maps API for Flash</a></li><li><a href="https://code.google.com/apis/earth/">Google Earth API</a></li><li><a href="https://code.google.com/apis/maps/documentation/staticmaps/">Static Maps API</a></li><li><a href="https://code.google.com/apis/maps/documentation/webservices/index.html">Web Services</a></li></ul></div><p>در ادامه شروع کار با Google Maps JavaScript API <abbr title="نسخه ۳">V3</abbr> را با هم بررسی می کنیم.</p><p>برای استفاده از این سرویس در وب سایت یا وبلاگ خود، قبل از هر چیز باید کلید لازم برای ارتباط دامنه خود با گوگل را بدست بیاورید. البته این کلید فقط در برخی مواقع ضروری است. دریافت این key با <a href="https://code.google.com/apis/maps/signup.html">ثبت نام در Google Maps API</a> براحتی از طرف گوگل برای شما نمایش داده می شود.</p><p><strong>ساده ترین نوع پیاده سازی (برنامه Hello, World)</strong></p><pre class="brush: xml; title: ; notranslate">
&lt;!DOCTYPE html&gt;
&lt;html&gt;
&lt;head&gt;
    &lt;meta name=&quot;viewport&quot; content=&quot;initial-scale=1.0, user-scalable=no&quot;/&gt;
    &lt;meta http-equiv=&quot;content-type&quot; content=&quot;text/html; charset=UTF-8&quot;/&gt;
    &lt;style type=&quot;text/css&quot;&gt;
        html {
            height: 100%
        }
        body {
            height: 100%;
            margin: 0px;
            padding: 0px
        }
        #map_canvas {
            height: 100%
        }
    &lt;/style&gt;
    &lt;title&gt;Google Maps JavaScript API v3 Example: Map Simple&lt;/title&gt;
    &lt;script type=&quot;text/javascript&quot; src=&quot;http://maps.google.com/maps/api/js?sensor=false&quot;&gt;&lt;/script&gt;
    &lt;script type=&quot;text/javascript&quot;&gt;
        function initialize() {
            var myLatlng = new google.maps.LatLng(35.695964, 51.417704);
            var myOptions = {
                zoom: 8,
                center: myLatlng,
                mapTypeId: google.maps.MapTypeId.ROADMAP
            }
            var map = new google.maps.Map(document.getElementById(&quot;map_canvas&quot;), myOptions);
        }
    &lt;/script&gt;
&lt;/head&gt;
&lt;body onload=&quot;initialize()&quot;&gt;
&lt;div id=&quot;map_canvas&quot;&gt;&lt;/div&gt;
&lt;/body&gt;
&lt;/html&gt;
</pre><p>کدهای بالا خیلی گویا هستند ولی چند نکته برای توجه وجود دارد:<br /> • با استفاده از &lt;!DOCTYPE html&gt; مشخص کردیم که مرورگر این صفحه را با استانداردهای html5 پردازش کند.<br /> • کدهای مربوط به API را در داخل تگ script قرار دادیم.<br /> • یک div با شناسه &#8220;map_canvas&#8221; برای نشان دادن نقشه در نظر گرفتیم.<br /> • با استفاده از اتریبیوت onload تگ body، نقشه را initialize یا مقداردهی اولیه کردیم.<br /> اطلاعات بیشتر در <a href="https://code.google.com/apis/maps/documentation/javascript/tutorial.html">Google Maps Javascript API V3 Tutorial</a> ارائه شده است.</p><p>همین مراحل برای نمایش نقشه زیر کافیست:</p><div style="text-align:center"> <iframe style="border: 1px solid #888" src ="http://zebardast.ir/wp-content/uploads/2011/01/google-map-simple.html" width="576" height="300"></p><p>خطا، مرورگر شما از iframe پشتیبانی نمی کند.</p><p></iframe></div><p>یکی از کارهایی که در حال انجام آن هستم، پیاده سازی مراکز پوشش اینترنت توسط یکی از شرکت های ارائه دهنده خدمات اینترنتیست. نمونه اولیه این کار را در زیر مشاهده می فرمایید:</p><p><script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script><br /><script type="text/javascript" src="http://zebardast.ir/wp-content/uploads/2011/01/google-map-overlay-sample.js"></script></p><div style="text-align:center"><div id="map_canvas" style="width:576px; height:300px; border: 1px solid #888"></div><div class="ltr"> Opacity: <a href="javascript:overlay.setOpacity(25)">25%</a> &nbsp; <a href="javascript:overlay.setOpacity(50)">50%</a> &nbsp; <a href="javascript:overlay.setOpacity(100)">100%</a></div></div><p><script type="text/javascript">
<!--
window.onload = initialize;
//--></script></p><p><strong>پیوندها</strong></p><div class="ltr"><ul><li><a href="http://goo.gl/maps/uPHs">Google Maps</a></li><li><a href="https://code.google.com/apis/maps/">Google Maps API Family</a></li><li><a href="https://code.google.com/apis/maps/signup.html">Sign Up for the Google Maps API</a></li><li><a href="https://code.google.com/apis/maps/documentation/javascript/basics.html">Google Maps Javascript API V3 Basics</a></li><li><a href="https://code.google.com/apis/maps/documentation/javascript/tutorial.html">Google Maps Javascript API V3 Tutorial</a></li><li><a href="https://code.google.com/apis/maps/documentation/javascript/demogallery.html">Google Maps Javascript API V3 Demo Gallery</a></li></ul></div><p><strong>پی نوشت</strong><br /> در صورتی که موفق به دیدن نقشه ها نشدید، از فیلترشکن برای دیدن آنها استفاده کنید. به دلیل تحریم، بعضی از خدمات گوگل بر روی کاربران ساکن ایران، محدود می باشد.</p><p>همیشه شاد، و موفق باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b4%25d8%25b1%25d9%2588%25d8%25b9-%25da%25a9%25d8%25a7%25d8%25b1-%25d8%25a8%25d8%25a7-google-maps-api%2F&amp;linkname=%D8%B4%D8%B1%D9%88%D8%B9%20%DA%A9%D8%A7%D8%B1%20%D8%A8%D8%A7%20Google%20Maps%20API" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b4%25d8%25b1%25d9%2588%25d8%25b9-%25da%25a9%25d8%25a7%25d8%25b1-%25d8%25a8%25d8%25a7-google-maps-api%2F&amp;linkname=%D8%B4%D8%B1%D9%88%D8%B9%20%DA%A9%D8%A7%D8%B1%20%D8%A8%D8%A7%20Google%20Maps%20API" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b4%25d8%25b1%25d9%2588%25d8%25b9-%25da%25a9%25d8%25a7%25d8%25b1-%25d8%25a8%25d8%25a7-google-maps-api%2F&amp;linkname=%D8%B4%D8%B1%D9%88%D8%B9%20%DA%A9%D8%A7%D8%B1%20%D8%A8%D8%A7%20Google%20Maps%20API" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25b4%25d8%25b1%25d9%2588%25d8%25b9-%25da%25a9%25d8%25a7%25d8%25b1-%25d8%25a8%25d8%25a7-google-maps-api%2F&amp;linkname=%D8%B4%D8%B1%D9%88%D8%B9%20%DA%A9%D8%A7%D8%B1%20%D8%A8%D8%A7%20Google%20Maps%20API" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d8%25b4%25d8%25b1%25d9%2588%25d8%25b9-%25da%25a9%25d8%25a7%25d8%25b1-%25d8%25a8%25d8%25a7-google-maps-api%2F&amp;title=%D8%B4%D8%B1%D9%88%D8%B9%20%DA%A9%D8%A7%D8%B1%20%D8%A8%D8%A7%20Google%20Maps%20API" id="wpa2a_16">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/google-ajax-search-api/' rel='bookmark' title='Google AJAX Search API، یک موتور جستجو در وبلاگ شما'>Google AJAX Search API، یک موتور جستجو در وبلاگ شما</a></li><li><a href='http://zebardast.ir/google-apps-for-your-domain/' rel='bookmark' title='Google Apps for Your Domain'>Google Apps for Your Domain</a></li><li><a href='http://zebardast.ir/%d8%b3%d8%a7%d8%ae%d8%aa-%d9%85%d9%88%d8%aa%d9%88%d8%b1-%d8%ac%d8%b3%d8%aa%d8%ac%d9%88%db%8c-%d8%b4%d8%ae%d8%b5%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-google-co-op/' rel='bookmark' title='ساخت موتور جستجوی شخصی با استفاده از Google Co-op'>ساخت موتور جستجوی شخصی با استفاده از Google Co-op</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d8%b4%d8%b1%d9%88%d8%b9-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-google-maps-api/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>وارد کردن اطلاعات از فایل به پایگاه داده MySQL</title><link>http://zebardast.ir/%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%a7%d8%b2-%d9%81%d8%a7%db%8c%d9%84-%d8%a8%d9%87-mysql/</link> <comments>http://zebardast.ir/%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%a7%d8%b2-%d9%81%d8%a7%db%8c%d9%84-%d8%a8%d9%87-mysql/#comments</comments> <pubDate>Mon, 25 Oct 2010 05:46:44 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[پایگاه داده MySQL]]></category> <category><![CDATA[import]]></category> <category><![CDATA[پایگاه داده]]></category><guid isPermaLink="false">http://zebardast.ir/</guid> <description><![CDATA[— MySQL سلام قبلا در مورد انتقال اطلاعات در MySQL توضیح دادم. مطلب امروز در زمینه وارد کردن اطلاعات (import) از یک فایل متنی (txt, csv و &#8230;) به پایگاه داده MySQL می باشد. برای وارد کردن اطلاعات از یک فایل به پایگاه داده MySQL از دستور `LOAD DATA INFILE` استفاده می کنیم. شکل کلی [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86import-%d9%88-%d8%b5%d8%a7%d8%af%d8%b1-%da%a9%d8%b1%d8%af%d9%86export-%d8%af%d8%b1-mysql/' rel='bookmark' title='راهنمای وارد کردن(import) و صادر کردن(export) در MySQL'>راهنمای وارد کردن(import) و صادر کردن(export) در MySQL</a></li><li><a href='http://zebardast.ir/%d8%a7%d9%86%d8%aa%d9%82%d8%a7%d9%84-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%af%d8%b1-mysql/' rel='bookmark' title='انتقال اطلاعات در MySQL'>انتقال اطلاعات در MySQL</a></li><li><a href='http://zebardast.ir/%d9%86%da%a9%d8%a7%d8%aa%db%8c-%d8%af%d8%b1-%d8%b2%d9%85%db%8c%d9%86%d9%87-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/' rel='bookmark' title='نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL'>نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL</a></li></ol>]]></description> <content:encoded><![CDATA[<div class="autocap alignleft" style="width: 110px;"><div><a href="http://zebardast.ir/wp-content/uploads/2010/10/logo-mysql-110x57.png"><img class=" size-full wp-image-1157" title="MySQL" src="http://zebardast.ir/wp-content/uploads/2010/10/logo-mysql-110x57.png" alt="" width="110" height="57" /></a><p class="autocap-text"><span class="hide">— </span>MySQL</p></div></div><p>سلام</p><p>قبلا در مورد <a href="http://zebardast.ir/%d8%a7%d9%86%d8%aa%d9%82%d8%a7%d9%84-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%af%d8%b1-mysql/">انتقال اطلاعات در MySQL</a> توضیح دادم. مطلب امروز در زمینه وارد کردن اطلاعات (import) از یک فایل متنی (txt, csv و &#8230;) به پایگاه داده MySQL می باشد. برای وارد کردن اطلاعات از یک فایل به پایگاه داده MySQL از دستور `LOAD DATA INFILE` استفاده می کنیم. شکل کلی این دستور به صورت زیر است:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name'
    [REPLACE | IGNORE]
    INTO TABLE tbl_name
    [CHARACTER SET charset_name]
    [{FIELDS | COLUMNS}
        [TERMINATED BY 'string']
        [[OPTIONALLY] ENCLOSED BY 'char']
        [ESCAPED BY 'char']
    ]
    [LINES
        [STARTING BY 'string']
        [TERMINATED BY 'string']
    ]
    [IGNORE number LINES]
    [(col_name_or_user_var,...)]
    [SET col_name = expr,...]
</pre><p>ساده ترین شکل استفاده از این دستور به شکل زیر می باشد:</p><pre class="brush: sql; title: ; notranslate">mysql&gt; LOAD DATA INFILE 'data.txt' INTO TABLE my_db.my_table;
</pre><p>در صورتی که جداکننده فیلد ها (FIELDS TERMINATED) را مشخص نکنید، MySQL مقدار پیش فرض <code>\t</code> که همان تب (Tab) هست را در نظر می گیرد. همچنین مقدار پیش فرض جداکننده خطوط <code>\n</code> که همان خط جدید (New Line) می باشد را در نظر می گیرد.<br /> <strong>نکته</strong><br /> در صورتی که فایل شما دارای کاراکترهای UTF8 می باشد، علاوه بر تعریف جدول my_table با encoding مربوط به UTF8، باید نوع encoding را نیز در دستور LOAD DATE بنویسید. به صورت:</p><pre class="brush: sql; title: ; notranslate">LOAD DATA INFILE 'data.txt' INTO TABLE my_db.my_table  character set UTF8;
</pre><p>در ادامه به بررسی یک مثال عملی در مورد واردکردن اطلاعات یک فایل <abbr title="Comma Separated Values">CSV</abbr> می پردازیم.</p><h3>بررسی یک مثال عملی</h3><p>فرض کنید فایلی به نام <code>ip-list.csv</code> با محتوای زیر دارید:</p><pre>
"1.0.0.0","1.0.0.255","16777216","16777471","AU","Australia"
"1.0.1.0","1.0.3.255","16777472","16778239","CN","China"
"1.0.4.0","1.0.7.255","16778240","16779263","AU","Australia"
"1.0.8.0","1.0.15.255","16779264","16781311","CN","China"
"1.0.16.0","1.0.31.255","16781312","16785407","JP","Japan"
"1.0.32.0","1.0.63.255","16785408","16793599","CN","China"
"1.0.64.0","1.0.127.255","16793600","16809983","JP","Japan"
"1.0.128.0","1.0.255.255","16809984","16842751","TH","Thailand"
"1.1.0.0","1.1.0.255","16842752","16843007","CN","China"
"1.1.1.0","1.1.1.255","16843008","16843263","AU","Australia"
"1.1.2.0","1.1.63.255","16843264","16859135","CN","China"
"1.1.64.0","1.1.127.255","16859136","16875519","JP","Japan"
</pre><p>این فایل تعدادی آی‌پی و کشور متناظر با آن‌ها را نمایش می دهد. برای وارد کردن این اطلاعات به پایگاه داده MySQL ابتدا باید جدولی مناسب با این داده‌ها بسازیم. برای آشنایی با انتخاب نوع مناسب داده می توانید به مطلب <a href="http://zebardast.ir/%D8%A7%D9%86%D9%88%D8%A7%D8%B9-%D8%AF%D8%A7%D8%AF%D9%87-%D9%87%D8%A7-%D8%AF%D8%B1-%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87-%D8%AF%D8%A7%D8%AF%D9%87-mysql/" title="انواع داده در MySQL">انواع داده در MySQL</a> مراجعه نمایید. دستور زیر یک جدول به نام geoip ایجاد می کند:</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; CREATE TABLE `geoip` (
  `begin_ip` varchar(15) NOT NULL,
  `end_ip` varchar(15) NOT NULL,
  `begin_num` int(11) unsigned NOT NULL,
  `end_num` int(11) unsigned NOT NULL,
  `country` char(2) NOT NULL,
  `name` varchar(50) NOT NULL
) ENGINE=MyISAM;
</pre><p>دستور زیر این اطلاعات را از فایل <code>ip-list.csv</code> به جدول <code>geoip</code> وارد می‌کند. در صورت نیاز باید آدرس صحیح فایل را نیز در کنار نام آن درج کنید.</p><pre class="brush: sql; title: ; notranslate">
mysql&gt; LOAD DATA INFILE 'ip-list.csv'
 INTO TABLE geoip
 FIELDS TERMINATED BY &quot;,&quot; ENCLOSED BY '&quot;';

Query OK, 12 rows affected (0.23 sec)
Records: 12  Deleted: 0  Skipped: 0  Warnings: 0
</pre><p>در دستور بالا مشخص کرده ایم که ستون‌ها با &#8220;,&#8221; جدا شده و محتوای هر ستون نیز در داخل دو <code>"</code> قرار دارد.</p><h3>منابع</h3><ul><li><a href="http://dev.mysql.com/doc/refman/5.1/en/load-data.html">LOAD DATA INFILE</a> (سایت رسمی MySQL)</li></ul><p><strong>پی نوشت</strong></p><ul><li>متاسفانه <a href="http://dev.mysql.com/">بخش توسعه پایگاه داده MySQL</a> با استناد به قانون جرایم رایانه ای  فیلتر شده است. امیدوارم مسئولین تفکر و تعقل بیشتری نسبت به فیلتر کردن سایت ها داشته باشند.</li><li>این مطلب به بهانه فیلتر شدن بخش توسعه پایگاه داده MySQL نوشته شده است.</li></ul><p>شاد باشید</p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2588%25d8%25a7%25d8%25b1%25d8%25af-%25da%25a9%25d8%25b1%25d8%25af%25d9%2586-%25d8%25a7%25d8%25b7%25d9%2584%25d8%25a7%25d8%25b9%25d8%25a7%25d8%25aa-%25d8%25a7%25d8%25b2-%25d9%2581%25d8%25a7%25db%258c%25d9%2584-%25d8%25a8%25d9%2587-mysql%2F&amp;linkname=%D9%88%D8%A7%D8%B1%D8%AF%20%DA%A9%D8%B1%D8%AF%D9%86%20%D8%A7%D8%B7%D9%84%D8%A7%D8%B9%D8%A7%D8%AA%20%D8%A7%D8%B2%20%D9%81%D8%A7%DB%8C%D9%84%20%D8%A8%D9%87%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2588%25d8%25a7%25d8%25b1%25d8%25af-%25da%25a9%25d8%25b1%25d8%25af%25d9%2586-%25d8%25a7%25d8%25b7%25d9%2584%25d8%25a7%25d8%25b9%25d8%25a7%25d8%25aa-%25d8%25a7%25d8%25b2-%25d9%2581%25d8%25a7%25db%258c%25d9%2584-%25d8%25a8%25d9%2587-mysql%2F&amp;linkname=%D9%88%D8%A7%D8%B1%D8%AF%20%DA%A9%D8%B1%D8%AF%D9%86%20%D8%A7%D8%B7%D9%84%D8%A7%D8%B9%D8%A7%D8%AA%20%D8%A7%D8%B2%20%D9%81%D8%A7%DB%8C%D9%84%20%D8%A8%D9%87%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2588%25d8%25a7%25d8%25b1%25d8%25af-%25da%25a9%25d8%25b1%25d8%25af%25d9%2586-%25d8%25a7%25d8%25b7%25d9%2584%25d8%25a7%25d8%25b9%25d8%25a7%25d8%25aa-%25d8%25a7%25d8%25b2-%25d9%2581%25d8%25a7%25db%258c%25d9%2584-%25d8%25a8%25d9%2587-mysql%2F&amp;linkname=%D9%88%D8%A7%D8%B1%D8%AF%20%DA%A9%D8%B1%D8%AF%D9%86%20%D8%A7%D8%B7%D9%84%D8%A7%D8%B9%D8%A7%D8%AA%20%D8%A7%D8%B2%20%D9%81%D8%A7%DB%8C%D9%84%20%D8%A8%D9%87%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d9%2588%25d8%25a7%25d8%25b1%25d8%25af-%25da%25a9%25d8%25b1%25d8%25af%25d9%2586-%25d8%25a7%25d8%25b7%25d9%2584%25d8%25a7%25d8%25b9%25d8%25a7%25d8%25aa-%25d8%25a7%25d8%25b2-%25d9%2581%25d8%25a7%25db%258c%25d9%2584-%25d8%25a8%25d9%2587-mysql%2F&amp;linkname=%D9%88%D8%A7%D8%B1%D8%AF%20%DA%A9%D8%B1%D8%AF%D9%86%20%D8%A7%D8%B7%D9%84%D8%A7%D8%B9%D8%A7%D8%AA%20%D8%A7%D8%B2%20%D9%81%D8%A7%DB%8C%D9%84%20%D8%A8%D9%87%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d9%2588%25d8%25a7%25d8%25b1%25d8%25af-%25da%25a9%25d8%25b1%25d8%25af%25d9%2586-%25d8%25a7%25d8%25b7%25d9%2584%25d8%25a7%25d8%25b9%25d8%25a7%25d8%25aa-%25d8%25a7%25d8%25b2-%25d9%2581%25d8%25a7%25db%258c%25d9%2584-%25d8%25a8%25d9%2587-mysql%2F&amp;title=%D9%88%D8%A7%D8%B1%D8%AF%20%DA%A9%D8%B1%D8%AF%D9%86%20%D8%A7%D8%B7%D9%84%D8%A7%D8%B9%D8%A7%D8%AA%20%D8%A7%D8%B2%20%D9%81%D8%A7%DB%8C%D9%84%20%D8%A8%D9%87%20%D9%BE%D8%A7%DB%8C%DA%AF%D8%A7%D9%87%20%D8%AF%D8%A7%D8%AF%D9%87%20MySQL" id="wpa2a_18">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86import-%d9%88-%d8%b5%d8%a7%d8%af%d8%b1-%da%a9%d8%b1%d8%af%d9%86export-%d8%af%d8%b1-mysql/' rel='bookmark' title='راهنمای وارد کردن(import) و صادر کردن(export) در MySQL'>راهنمای وارد کردن(import) و صادر کردن(export) در MySQL</a></li><li><a href='http://zebardast.ir/%d8%a7%d9%86%d8%aa%d9%82%d8%a7%d9%84-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%af%d8%b1-mysql/' rel='bookmark' title='انتقال اطلاعات در MySQL'>انتقال اطلاعات در MySQL</a></li><li><a href='http://zebardast.ir/%d9%86%da%a9%d8%a7%d8%aa%db%8c-%d8%af%d8%b1-%d8%b2%d9%85%db%8c%d9%86%d9%87-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87-%d8%af%d8%a7%d8%af%d9%87-mysql/' rel='bookmark' title='نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL'>نکاتی در زمینه استفاده راحت تر از پایگاه داده MySQL</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d9%88%d8%a7%d8%b1%d8%af-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa-%d8%a7%d8%b2-%d9%81%d8%a7%db%8c%d9%84-%d8%a8%d9%87-mysql/feed/</wfw:commentRss> <slash:comments>1</slash:comments> </item> <item><title>خزنده وب (Web Crawler)</title><link>http://zebardast.ir/%d8%ae%d8%b2%d9%86%d8%af%d9%87-%d9%88%d8%a8-web-crawler/</link> <comments>http://zebardast.ir/%d8%ae%d8%b2%d9%86%d8%af%d9%87-%d9%88%d8%a8-web-crawler/#comments</comments> <pubDate>Sun, 27 Jun 2010 05:15:00 +0000</pubDate> <dc:creator>سعید زبردست</dc:creator> <category><![CDATA[برنامه نویسی]]></category> <category><![CDATA[برنامه نویسی وب]]></category> <category><![CDATA[جاوا]]></category> <category><![CDATA[علوم کامپیوتر]]></category> <category><![CDATA[Web Crawler]]></category> <category><![CDATA[جستجو]]></category> <category><![CDATA[خزنده وب]]></category><guid isPermaLink="false">http://zebardast.ir/?p=1076</guid> <description><![CDATA[سلام مطلب امروز ضمن آشنا کردن شما با Web crawler و معماری آن، سورس خزنده وب ساده ای به زبان جاوا را ارائه می دهد. خزنده وب (Web Crawler) چیست؟ خزنده وب که بیشتر ما آن را با عنوان Web crawler می شناسیم به برنامه کامپیوتری اطلاق می شود که World Wide Web (وب جهان گستر) را [...] <strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%85%d8%b9%d8%b1%d9%81%db%8c-%d9%88-%d8%a2%d9%85%d9%88%d8%b2%d8%b4-%d9%be%db%8c%d8%a7%d8%af%d9%87%e2%80%8c%d8%b3%d8%a7%d8%b2%db%8c-apache-lucene/' rel='bookmark' title='معرفی و آموزش پیاده‌سازی Apache Lucene'>معرفی و آموزش پیاده‌سازی Apache Lucene</a></li><li><a href='http://zebardast.ir/%d9%85%d8%b9%d8%a7%d9%87%d8%af%d9%87%e2%80%8c%d9%87%d8%a7%db%8c-%da%a9%d8%af-%d9%86%d9%88%db%8c%d8%b3%db%8c-coding-conventions/' rel='bookmark' title='معاهده‌های کدنویسی (Coding conventions)'>معاهده‌های کدنویسی (Coding conventions)</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%af%d8%b3%d8%aa-%d8%a2%d9%88%d8%b1%d8%af%d9%86-%da%a9%d8%b4%d9%88%d8%b1-%db%8c%da%a9-%d8%a2%d8%af%d8%b1%d8%b3-ip-%d8%a8%d9%87-%da%a9%d9%85%da%a9-mysql/' rel='bookmark' title='بدست آوردن کشور یک آدرس IP به کمک MySQL'>بدست آوردن کشور یک آدرس IP به کمک MySQL</a></li></ol>]]></description> <content:encoded><![CDATA[<p>سلام <img src='http://zebardast.ir/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /></p><p>مطلب امروز ضمن آشنا کردن شما با <a href="http://en.wikipedia.org/wiki/Web_crawler">Web crawler</a> و معماری آن، سورس خزنده وب ساده ای به زبان جاوا را ارائه می دهد.</p><h3>خزنده وب (Web Crawler) چیست؟</h3><p>خزنده وب که بیشتر ما آن را با عنوان Web crawler می شناسیم به برنامه کامپیوتری اطلاق می شود که World Wide Web (وب جهان گستر) را به صورت مرتب و سلسله مراتبی بازدید کرده و اطلاعات آن را مورد پردازش قرار می دهد. از Web crawler ها با عناوین دیگری مانند ants, automatic indexers, bots, Web spiders و Web robots نیز یاد می شود.</p><h3>کاربرد ها</h3><p>۱- موتورهای جستجو</p><p>موتورهای جستجو و برخی از سایت ها دارای خزنده ها ویا روبات هایی هستند که برای گردآوری اطلاعات وب سایت ها و نیز بروز نگه داشتن اطلاعات مورد استفاده قرار می گیرند. مهم ترین کار بعد از گردآوری اطلاعات، ایندکس کردن آن ها برای پردازش سریع هنگام جستجو است. این خزنده ها معمولا در بازه های زمانی منظمی اطلاعات را بروز کرده و با نسخه های قبلی مقایسه می کنند.</p><p>۲- مدیریت فنی وب سایت</p><p>مدیریت فنی وب سایت بخشی از کار این خزنده هاست که شامل یافتن لینک های شکسته (Broken Link) ، اعتبار سنجی (Validation) کدهای HTML، فایل های CSS و &#8230; می باشد.</p><p>۳- جمع آوری اطلاعات خاص</p><p>کاربرد دیگر خزنده های  وب جمع آوری اطلاعات خاصی مانند آدرس های ایمیل است. معمولا هدف از اینکار ارسال هرزنامه (spam) می باشد. برای جلوگیری از ثبت آدرس ایمیل توسط این خزنده ها، می توانید آدرس ایمیل خود را به صورت saeidREMOVEME AT جیمیل و یا موارد مشابه دیگر بنویسید.</p><h3>نحوه کار</h3><p>به صورت عمومی نحوه کار Web crawler ها به این صورت است که ابتدا لیستی از URL ها (آدرس های وب) که به عنوان seed شناخته می شوند را برای بازدید پردازش می کنند. هنگام پردازش این آدرس ها، لیست لینک ها و آدرس های موجود در صفحات آن ها را گردآوری کرده و به لیست ابتدایی اضافه می کنند. بقیه اطلاعات را نیز با توجه به نیاز و هدف خود ذخیره  و پردازش می نمایند.</p><h3>معماری خزنده وب</h3><p>خزنده وب بخش اصلی و مرکزی هر موتور جستجویی را تشکیل می دهد. به همین جهت الگوریتم و معماری آن ها به شدت مخفی نگه داشته می شود. با این وجود معماری سطح بالای (High-level architecture) آن به شکل زیر می باشد:</p><div class="autocap aligncenter" style="width: 500px;"><div><img class=" size-full wp-image-1109" title="معماری سطح بالای یک خزنده وب استاندارد (عکس از ویکی پدیا)" src="http://zebardast.ir/wp-content/uploads/2010/06/WebCrawlerArchitecture.png" alt="" width="500" height="382" /><p class="autocap-text"><span class="hide">— </span>معماری سطح بالای یک خزنده وب استاندارد (عکس از ویکی پدیا)</p></div></div><h3>عادی کردن آدرس (URL normalization)</h3><p>منظور از عادی کردن آدرس، یکی کردن آدرس هایی می باشد که دارای خروجی یکسانی هستند. هدف از این کار جلوگیری از جمع آوری اطلاعات یکسان از چندین URL می باشد. URL normalization با نام URL canonicalization نیز شناخته می شود که همان فرآیند تغییر آدرس برای استاندارد شدن می باشد.</p><h3>مراحل فرایند عادی کردن آدرس</h3><p>• تبدیل آدرس به حروف کوچک</p><pre>HTTP://www.Example.com/ → http://www.example.com/</pre><p>• افزودن / به آدرس در صورت نیاز</p><pre>http://www.example.com → http://www.example.com/</pre><p>• حذف آدرس ایندکس دایرکتوری</p><pre>http://www.example.com/default.asp → http://www.example.com/
http://www.example.com/a/index.html → http://www.example.com/a/</pre><p>• بزرگ کردن حروف encode شده یا همان حروف بعد از علامت ٪</p><pre>http://www.example.com/a%c2%b1b → http://www.example.com/a%C2%B1b</pre><p>• حذف بخش زاید</p><pre>http://www.example.com/bar.html#section1 → http://www.example.com/bar.html</pre><p>• حذف و تبدیل آی پی به دامنه</p><pre>http://208.77.188.166/ → http://www.example.com/</pre><p>• اعمال محدودیت بر روی پروتکل ها مانند تبدیل https به http</p><pre>https://www.example.com/ → http://www.example.com/</pre><p>• حذف پورت پیش فرض (پورت ۸۰ به صورت پیش فرض برای http می باشد)</p><pre>http://www.example.com:80/bar.html → http://www.example.com/bar.html</pre><p>• حذف / های تکراری</p><pre>http://www.example.com:80/bar.html → http://www.example.com/bar.html</pre><p>• حذف . ها (dot-segments)</p><pre>http://www.example.com/../a/b/../c/./d.html → http://www.example.com/a/c/d.html</pre><p>• حذف www از اول دامنه</p><pre>http://www.example.com/ → http://example.com/</pre><p>• مرتب کردن متغییرهای صفحه فعال</p><pre>http://www.example.com/display?lang=en&amp;article=fred
 → http://www.example.com/display?article=fred〈=en</pre><p>• حذف متغییرهای اختیاری از <strong><span style="font-weight: normal;">query-string</span> </strong></p><pre>http://www.example.com/display?id=123&amp;fakefoo=fakebar
 → http://www.example.com/display?id=123</pre><p>• حذف متغییرهای پیش فرض از query-string</p><pre>http://www.example.com/display?id=&amp;sort=ascending
 → http://www.example.com/display</pre><p>• حذف علامت ? هنگامی که query-string خالی باشد</p><pre>http://www.example.com/display? → http://www.example.com/display</pre><p>• استانداردکردن encoding کاراکترها</p><pre>http://www.example.com/display?category=foo/bar+baz
 → http://www.example.com/display?category=foo%2Fbar%20baz</pre><h3>شناسایی خزنده وب</h3><p>خزنده های وب معمولا با استفاده از فیلد User-agent داده HTTP request خود را معرفی می کنند. شما با استفاده از لاگ وب سرور خود می توانید لیست این Web crawler های را مشاهده کنید. فیلد User agent ممکن است شامل URL ای باشد که به سایت سازنده خزنده اشاره می کند.</p><p>Spambot ها و سایر خزنده های مخرب معمولا فیلد User agent را به صورت غیر واقعی با اطلاعاتی مانند نام یک مرورگر پر می کنند.</p><h3>فایل robots.txt</h3><p>این فایل برای دادن اطلاعات اولیه در زمینه وب سایت مورد پردازش به خزنده های وب استفاده می گردد. به عنوان مثال با این فایل می توانید دسترسی خزنده های وب به بعضی زیر شاخه ها محدود کنید. دستورات زیر در فایل robots.txt از دسترسی خزنده ها به دایرکتوری /tmp/ جلوگیری می کند:</p><pre>User-agent: *
Disallow: /tmp/</pre><p>* فایل robots.txt یک استاندارد می باشد. به همین جهت خزنده وب (معمولا خزنده مخرب) می تواند آن را نادیده بگیرد.</p><h3>معروف ترین خزنده های وب غیر آزاد</h3><p>در زیر لیست معروف ترین خزنده های وب را مشاهده می کنید:</p><ul class="ltr"><li><a href="http://en.wikipedia.org/wiki/Yahoo!_Slurp">Yahoo! Slurp</a></li><li><a href="http://en.wikipedia.org/wiki/Msnbot">Msnbot</a></li><li>FAST Crawler</li><li><a href="http://en.wikipedia.org/wiki/Googlebot">Googlebot</a></li><li><a href="http://en.wikipedia.org/wiki/Methabot">Methabot</a></li><li><a href="http://arachnode.net/">arachnode.net</a></li><li>PolyBot</li><li>RBSE</li><li><a href="http://en.wikipedia.org/wiki/WebCrawler">WebCrawler</a></li><li>World Wide Web Worm</li><li><a href="http://en.wikipedia.org/wiki/WebFountain">WebFountain</a></li><li>WebRACE</li></ul><h3>معروف ترین خزنده های متن باز</h3><ul class="ltr"><li><a title="Aspseek" href="http://en.wikipedia.org/wiki/Aspseek">Aspseek</a></li><li><a href="http://code.google.com/p/crawler4j/">crawler4j</a></li><li><a title="DataparkSearch" href="http://en.wikipedia.org/wiki/DataparkSearch">DataparkSearch</a></li><li><a href="http://en.wikipedia.org/w/index.php?title=Ebot&amp;action=edit&amp;redlink=1">Ebot</a></li><li><a title="Wget" href="http://en.wikipedia.org/wiki/Wget">GNU Wget</a></li><li><a title="Grub (search engine)" href="http://en.wikipedia.org/wiki/Grub_(search_engine)">GRUB</a></li><li><a title="Heritrix" href="http://en.wikipedia.org/wiki/Heritrix">Heritrix</a></li><li><a class="mw-redirect" title="Ht-//dig" href="http://en.wikipedia.org/wiki/Ht-//dig">ht://Dig</a></li><li><a title="HTTrack" href="http://en.wikipedia.org/wiki/HTTrack">HTTrack</a></li><li><a title="ICDL crawling" href="http://en.wikipedia.org/wiki/ICDL_crawling">ICDL Crawler</a></li><li><a title="MnoGoSearch" href="http://en.wikipedia.org/wiki/MnoGoSearch">mnoGoSearch</a></li><li><a title="Nutch" href="http://en.wikipedia.org/wiki/Nutch">Nutch</a></li><li><a class="mw-redirect" title="Open Search Server" href="http://en.wikipedia.org/wiki/Open_Search_Server">Open Search Server</a></li><li><a title="Pavuk" href="http://en.wikipedia.org/wiki/Pavuk">Pavuk</a></li><li><a title="YaCy" href="http://en.wikipedia.org/wiki/YaCy">YaCy</a></li></ul><h3>سورس خزنده وب به زبان جاوا</h3><p>سایت sun در سال ۱۹۹۸ مقاله ای آموزشی با عنوان &#8220;<a href="http://java.sun.com/developer/technicalArticles/ThirdParty/WebCrawler/" target="_blank">Writing a Web Crawler in the Java Programming Language</a>&#8221; را ارائه داد. در آن مقاله ضمن توضیح دادن Web crawler سورس برنامه آن نیز در اختیار عموم قرار گرفت. البته این برنامه خیلی ساده و در مرحله ابتدایی می باشد. شما باید با توجه به نیازهای خود آن را تغییر داده و مورد استفاده قرار دهید.</p><p>• دانلود <a href="http://java.sun.com/developer/technicalArticles/ThirdParty/WebCrawler/WebCrawler.java">سورس خزنده وب به زبان جاوا</a> (<a href="http://zebardast.ir/wp-content/uploads/2010/06/WebCrawler.txt">لینک کمکی</a>)</p><h3>کاربرد خزنده وب برای من</h3><p>برای سایت هایی که از نرم افزار های آماده مثل وردپرس استفاده نشده است و نیاز به موتور جستجو احساس می شد، با استفاده از خزنده ای که نوشتم، اطلاعات کل وب سایت مورد نظر را در داخل یک جدول در پایگاه داده ذخیره کردم. سپس توابعی برای جستجو بهینه بر روی داده ها در MySQL نوشتم و با استفاده از آن ها بخش جستجوی وب سایت مورد نظر را راه اندازی کردم. نمونه این جستجو ها در سایت های زیر فعال می باشد:</p><p>• <a href="http://datak-telecom.net/" target="_blank">داتک تله کام</a></p><p>• <a href="http://www.efstelecom.com/" target="_blank">ارتباطات فرادانش سامان</a></p><h3>منابع</h3><ul class="ltr"><li><a href="http://en.wikipedia.org/wiki/Web_crawler">Web crawler</a></li><li><a href="http://en.wikipedia.org/wiki/URL_normalization">URL normalization</a></li><li><a href="http://en.wikipedia.org/wiki/Robots_exclusion_standard">Robots exclusion standard</a></li></ul><p>موفق باشید <img src='http://zebardast.ir/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /></p><p><a class="a2a_button_google_plus" href="http://www.addtoany.com/add_to/google_plus?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25ae%25d8%25b2%25d9%2586%25d8%25af%25d9%2587-%25d9%2588%25d8%25a8-web-crawler%2F&amp;linkname=%D8%AE%D8%B2%D9%86%D8%AF%D9%87%20%D9%88%D8%A8%20%28Web%20Crawler%29" title="Google+" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/google_plus.png" width="16" height="16" alt="Google+"/></a><a class="a2a_button_facebook" href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25ae%25d8%25b2%25d9%2586%25d8%25af%25d9%2587-%25d9%2588%25d8%25a8-web-crawler%2F&amp;linkname=%D8%AE%D8%B2%D9%86%D8%AF%D9%87%20%D9%88%D8%A8%20%28Web%20Crawler%29" title="Facebook" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a><a class="a2a_button_twitter" href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25ae%25d8%25b2%25d9%2586%25d8%25af%25d9%2587-%25d9%2588%25d8%25a8-web-crawler%2F&amp;linkname=%D8%AE%D8%B2%D9%86%D8%AF%D9%87%20%D9%88%D8%A8%20%28Web%20Crawler%29" title="Twitter" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a><a class="a2a_button_identi_ca" href="http://www.addtoany.com/add_to/identi_ca?linkurl=http%3A%2F%2Fzebardast.ir%2F%25d8%25ae%25d8%25b2%25d9%2586%25d8%25af%25d9%2587-%25d9%2588%25d8%25a8-web-crawler%2F&amp;linkname=%D8%AE%D8%B2%D9%86%D8%AF%D9%87%20%D9%88%D8%A8%20%28Web%20Crawler%29" title="Identi.ca" rel="nofollow" target="_blank"><img src="http://zebardast.ir/wp-content/plugins/add-to-any/icons/identica.png" width="16" height="16" alt="Identi.ca"/></a><a class="a2a_dd a2a_target addtoany_share_save" href="http://www.addtoany.com/share_save#url=http%3A%2F%2Fzebardast.ir%2F%25d8%25ae%25d8%25b2%25d9%2586%25d8%25af%25d9%2587-%25d9%2588%25d8%25a8-web-crawler%2F&amp;title=%D8%AE%D8%B2%D9%86%D8%AF%D9%87%20%D9%88%D8%A8%20%28Web%20Crawler%29" id="wpa2a_20">اشتراک‌گذاری</a></p><p><strong>مطالب مرتبط:</strong><ol><li><a href='http://zebardast.ir/%d9%85%d8%b9%d8%b1%d9%81%db%8c-%d9%88-%d8%a2%d9%85%d9%88%d8%b2%d8%b4-%d9%be%db%8c%d8%a7%d8%af%d9%87%e2%80%8c%d8%b3%d8%a7%d8%b2%db%8c-apache-lucene/' rel='bookmark' title='معرفی و آموزش پیاده‌سازی Apache Lucene'>معرفی و آموزش پیاده‌سازی Apache Lucene</a></li><li><a href='http://zebardast.ir/%d9%85%d8%b9%d8%a7%d9%87%d8%af%d9%87%e2%80%8c%d9%87%d8%a7%db%8c-%da%a9%d8%af-%d9%86%d9%88%db%8c%d8%b3%db%8c-coding-conventions/' rel='bookmark' title='معاهده‌های کدنویسی (Coding conventions)'>معاهده‌های کدنویسی (Coding conventions)</a></li><li><a href='http://zebardast.ir/%d8%a8%d8%af%d8%b3%d8%aa-%d8%a2%d9%88%d8%b1%d8%af%d9%86-%da%a9%d8%b4%d9%88%d8%b1-%db%8c%da%a9-%d8%a2%d8%af%d8%b1%d8%b3-ip-%d8%a8%d9%87-%da%a9%d9%85%da%a9-mysql/' rel='bookmark' title='بدست آوردن کشور یک آدرس IP به کمک MySQL'>بدست آوردن کشور یک آدرس IP به کمک MySQL</a></li></ol></p>]]></content:encoded> <wfw:commentRss>http://zebardast.ir/%d8%ae%d8%b2%d9%86%d8%af%d9%87-%d9%88%d8%a8-web-crawler/feed/</wfw:commentRss> <slash:comments>20</slash:comments> </item> </channel> </rss>
<!-- Performance optimized by W3 Total Cache. Learn more: http://www.w3-edge.com/wordpress-plugins/

Minified using disk: basic
Page Caching using disk: enhanced
Database Caching 26/134 queries in 0.191 seconds using disk: basic
Object Caching 7045/7172 objects using disk: basic

Served from: zebardast.ir @ 2012-05-22 01:23:21 -->
