<?xml version='1.0' encoding='UTF-8'?><?xml-stylesheet href="http://www.blogger.com/styles/atom.css" type="text/css"?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:georss='http://www.georss.org/georss'><id>tag:blogger.com,1999:blog-2669059752766299103</id><updated>2009-10-17T18:56:06.404-07:00</updated><title type='text'>AWAT Blog</title><subtitle type='html'>Eclipse,Netbeans,Java,PHP,C/C++/C#,.NET,Visual Studio</subtitle><link rel='http://schemas.google.com/g/2005#feed' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/posts/default'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/'/><link rel='hub' href='http://pubsubhubbub.appspot.com/'/><link rel='next' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default?start-index=26&amp;max-results=25'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email></author><generator version='7.00' uri='http://www.blogger.com'>Blogger</generator><openSearch:totalResults>88</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>25</openSearch:itemsPerPage><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-3481171046855333150</id><published>2009-09-30T21:23:00.000-07:00</published><updated>2009-09-30T21:24:20.328-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='wysiwyg editor asp.net'/><category scheme='http://www.blogger.com/atom/ns#' term='auto increment'/><category scheme='http://www.blogger.com/atom/ns#' term='auto number'/><category scheme='http://www.blogger.com/atom/ns#' term='gridview'/><title type='text'>Auto increment in GridView</title><content type='html'>&amp;lt;asp:TemplateField HeaderText="Msg No"&amp;gt;&lt;br /&gt;&amp;lt;itemtemplate &amp;gt;&lt;br /&gt;&amp;lt;%#Container.DataItemIndex + 1%&amp;gt;&lt;br /&gt;&amp;lt;/ItemTemplate&amp;gt;&lt;br /&gt;&amp;lt;/asp:TemplateField&amp;gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-3481171046855333150?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/3481171046855333150/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=3481171046855333150' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3481171046855333150'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3481171046855333150'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2009/09/auto-increment-in-gridview.html' title='Auto increment in GridView'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-3310674845933593939</id><published>2009-01-10T08:31:00.000-08:00</published><updated>2009-01-10T08:32:13.948-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='PHP'/><title type='text'>Page Navigator Likes Google</title><content type='html'>&lt;?&lt;br /&gt;&lt;br /&gt; //Page Navigator Likes Google&lt;br /&gt; //By EThaiZone&lt;br /&gt;&lt;br /&gt; //Current Page - เลขหน้าปัจจุบัน&lt;br /&gt; $page = !empty($_GET['page']) ? $_GET['page'] : 1;&lt;br /&gt;&lt;br /&gt; //Total Pages - จำนวนหน้าทั้งหมด&lt;br /&gt; $all = 100;&lt;br /&gt;&lt;br /&gt; //Amount of link's page - จำนวนลิงค์ที่แสดง (ถ้าเป็น 10 คือหน้า 10 หลัง 10  วิธีคิดเหมือนลิงค์ Google)&lt;br /&gt; $amount_link_page = 10;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt; #########################&lt;br /&gt;&lt;br /&gt; if($page &gt; 1) {&lt;br /&gt;  if($page == 2) &lt;br /&gt;   $nav = " &lt;a href=\"".$_SERVER['PHP_SELF']."\"&gt;[Previous]&lt;/a&gt; ";&lt;br /&gt;  else&lt;br /&gt;   $nav = " &lt;a href=\"".$_SERVER['PHP_SELF']."?page=".($page-1)."\"&gt;[Previous]&lt;/a&gt; ";&lt;br /&gt; }&lt;br /&gt;&lt;br /&gt; $show = empty($amount_link_page) ? $all : $amount_link_page;&lt;br /&gt; $start = ($page &lt;= $show) ? 1 : $page-$show;&lt;br /&gt; $end = (($all-$page)&lt;$show ? $all+1 : $page+$show);&lt;br /&gt;&lt;br /&gt; for($i=$start; $i&lt;$end; $i++) {&lt;br /&gt;  if($i == 1 &amp;&amp; $i!=$page) &lt;br /&gt;   $nav .= " &lt;a href=\"".$_SERVER['PHP_SELF']."\"&gt;1&lt;/a&gt; ";&lt;br /&gt;  else if($i!=$page) &lt;br /&gt;   $nav .= " &lt;a href=\"".$_SERVER['PHP_SELF']."?page=$i\"&gt;$i&lt;/a&gt; ";&lt;br /&gt;  else &lt;br /&gt;   $nav .="&lt;b&gt;[".$i."]&lt;/b&gt;";&lt;br /&gt; }&lt;br /&gt;&lt;br /&gt; if(($all-$page) &gt; 0) {&lt;br /&gt;  $nav .= " &lt;a href=\"".$_SERVER['PHP_SELF']."?page=".($page+1)."\"&gt;[Next]&lt;/a&gt; ";&lt;br /&gt; }&lt;br /&gt;&lt;br /&gt; #########################&lt;br /&gt;&lt;br /&gt; //Show link - แสดงลิงค์&lt;br /&gt; echo $nav;&lt;br /&gt;&lt;br /&gt;?&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-3310674845933593939?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/3310674845933593939/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=3310674845933593939' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3310674845933593939'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3310674845933593939'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2009/01/page-navigator-likes-google.html' title='Page Navigator Likes Google'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-7971357289301134350</id><published>2009-01-07T08:40:00.000-08:00</published><updated>2009-01-07T08:47:00.989-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='linux'/><title type='text'>Compile C++ code in ubuntu</title><content type='html'>One of many question of user who switch from window to linux to have how to compile c/c++ source code. Most of study c or c++ at school or home an are usually use windows.&lt;br /&gt;&lt;br /&gt;I think simple to start compile c/c++ in ubuntu to use first an editor  like nano and create a source file then compile using gcc in command line. but first to install gcc complier and survival other utilities for compile software. use . &lt;br /&gt;&lt;br /&gt;sodu apt-get install build-essential&lt;br /&gt;&lt;br /&gt;build-essential is a meta package - a package which only depends on other packages, so installing it will automatically install several tools like gcc, g++ or make.&lt;br /&gt;&lt;br /&gt;Next, create your source file using a text editor of choice (I used Nano for this example):&lt;br /&gt;&lt;br /&gt;nano main.c&lt;br /&gt;&lt;br /&gt;Enter the content, e.g.:&lt;br /&gt;&lt;br /&gt;#include &lt;stdio.h&gt;&lt;br /&gt;&lt;br /&gt;int main ()&lt;br /&gt;{&lt;br /&gt;printf ("Hello, world!\n");&lt;br /&gt;return 0;&lt;br /&gt;}&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Notice that I also included a newline after the close bracket, otherwise the compiler will issue a warning. Save it with CTRL+O, then exit Nano using CTRL+X. To compile your source, simply use:&lt;br /&gt;&lt;br /&gt;gcc main.c -o myapp&lt;br /&gt;&lt;br /&gt;The output, myapp, will automatically be executable, so to run it use:&lt;br /&gt;&lt;br /&gt;ubuntu@ubuntu:~$ ./myapp&lt;br /&gt;Hello, world!&lt;br /&gt;&lt;br /&gt;This is the simplest way of creating and compiling C or C++ code.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-7971357289301134350?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/7971357289301134350/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=7971357289301134350' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/7971357289301134350'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/7971357289301134350'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2009/01/compile-c-code-in-ubuntu.html' title='Compile C++ code in ubuntu'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-3214879366970595260</id><published>2009-01-05T10:22:00.000-08:00</published><updated>2009-01-05T10:39:03.591-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='mysql'/><title type='text'>Speed Up Mysql query cache size</title><content type='html'>One of the best ways to speed up your web application is to enable query caching in your database, which caches commonly used SQL queries in memory for virtually instant access by the next page that makes the same request.&lt;br /&gt;&lt;br /&gt;The reason this method is so powerful is that you don't have to make any changes to your web application, you just have to sacrifice a little bit of memory. This isn't going to fix all of your problems, but it definitely can't hurt.&lt;br /&gt;&lt;br /&gt;Note: if your application updates tables frequently, then the query cache will be constantly purged and you won't get much or any benefit from this. This is ideal for an application that mostly does reads against the database, such as a Wordpress blog. This also won't work if you are running on shared hosting.&lt;br /&gt;&lt;br /&gt;Enable Caching with Server Running&lt;br /&gt;&lt;br /&gt;The first thing you'll want to do is make sure that your installation of MySQL actually has query caching support available. Most distributions do, but you should check anyway.&lt;br /&gt;&lt;br /&gt;You'll want to run this command from your MySQL console, which will tell you if query caching is available.&lt;br /&gt;&lt;br /&gt;    mysql&gt; show variables like 'have_query_cache';&lt;br /&gt;    +------------------+-------+&lt;br /&gt;    | Variable_name    | Value |&lt;br /&gt;    +------------------+-------+&lt;br /&gt;    | have_query_cache | YES   |&lt;br /&gt;    +------------------+-------+&lt;br /&gt;&lt;br /&gt;Don't mistake this as meaning that query caching is actually enabled, because most hosting providers aren't going to enable this by default. Oddly enough, my Ubuntu Feisty installation already had it enabled…&lt;br /&gt;&lt;br /&gt;Next we'll need to check and see if query caching is enabled. We'll need to check more than one variable, so we may as well do it all at once by checking for the variable query%&lt;br /&gt;&lt;br /&gt;    mysql&gt; show variables like 'query%';&lt;br /&gt;    +------------------------------+---------+&lt;br /&gt;    | Variable_name                | Value   |&lt;br /&gt;    +------------------------------+---------+&lt;br /&gt;    | query_alloc_block_size       | 8192    |&lt;br /&gt;    | query_cache_limit            | 1048576 |&lt;br /&gt;    | query_cache_min_res_unit     | 4096    |&lt;br /&gt;    | query_cache_size             | 8388608 |&lt;br /&gt;    | query_cache_type             | ON      |&lt;br /&gt;    | query_cache_wlock_invalidate | OFF     |&lt;br /&gt;    | query_prealloc_size          | 8192    |&lt;br /&gt;    +------------------------------+---------+&lt;br /&gt;&lt;br /&gt;Here's the important items in the list and what they mean:&lt;br /&gt;&lt;br /&gt;    * query_cache_size - This is the size of the cache in bytes. Setting this value to 0 will effectively disable caching.&lt;br /&gt;    * query_cache_type - This value must be ON or 1 for query caching to be enabled by default.&lt;br /&gt;    * query_cache_limit - This is the maximum size query (in bytes) that will be cached.&lt;br /&gt;&lt;br /&gt;If the query_cache_size value is set to 0 or you just want to change it, you'll need to run the following command, keeping in mind that the value is in bytes. For instance, if you wanted to allocate 8MB to the cache we'd use 1024 * 1024 * 8 = 8388608 as the value.&lt;br /&gt;&lt;br /&gt;    SET GLOBAL query_cache_size = 8388608;&lt;br /&gt;&lt;br /&gt;Similarly, the other options can be set with the same syntax:&lt;br /&gt;&lt;br /&gt;    SET GLOBAL query_cache_limit = 1048576;&lt;br /&gt;&lt;br /&gt;    SET GLOBAL query_cache_type = 1;&lt;br /&gt;&lt;br /&gt;Now how do we tell if it's actually working? You can use the SHOW STATUS command to pull all the variables that start with "Qc" to take a look at what is going on under the hood.&lt;br /&gt;&lt;br /&gt;    mysql&gt; SHOW STATUS LIKE 'Qc%';&lt;br /&gt;    +-------------------------+--------+&lt;br /&gt;    | Variable_name           | Value  |&lt;br /&gt;    +-------------------------+--------+&lt;br /&gt;    | Qcache_free_blocks      | 65     |&lt;br /&gt;    | Qcache_free_memory      | 201440 |&lt;br /&gt;    | Qcache_hits             | 18868  |&lt;br /&gt;    | Qcache_inserts          | 2940   |&lt;br /&gt;    | Qcache_lowmem_prunes    | 665    |&lt;br /&gt;    | Qcache_not_cached       | 246    |&lt;br /&gt;    | Qcache_queries_in_cache | 492    |&lt;br /&gt;    | Qcache_total_blocks     | 1430   |&lt;br /&gt;    +-------------------------+--------+&lt;br /&gt;    8 rows in set (0.00 sec)&lt;br /&gt;&lt;br /&gt;You'll notice in the stats that I have plenty of free memory left. If your server shows a lot of lowmem prunes, you might need to consider increasing this value, but I wouldn't spend too much memory on query caching for a web server… you need to leave memory available for apache, php, ruby, or whatever you are using.&lt;br /&gt;&lt;br /&gt;Enable in Config File&lt;br /&gt;&lt;br /&gt;If you want these changes to survive a reboot or restart of the mysql server, you'll need to add them into your /etc/mysql/my.cnf configuration file for MySQL. Note that it might be in a different location on your installation.&lt;br /&gt;&lt;br /&gt;Open up the file using a text editor in sudo or root mode, and then add these values if they don't already exist in the file. If they do exist, just uncomment them.&lt;br /&gt;&lt;br /&gt;    query_cache_size = 268435456&lt;br /&gt;    query_cache_type=1&lt;br /&gt;    query_cache_limit=1048576&lt;br /&gt;&lt;br /&gt;Query caching can significantly improve the speed of your web application, especially if your application does mostly reads. Monitor the status using the methods above and see how it works over time.&lt;br /&gt;&lt;br /&gt;link : http://www.howtogeek.com/howto/programming/speed-up-your-web-site-with-mysql-query-caching/&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-3214879366970595260?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/3214879366970595260/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=3214879366970595260' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3214879366970595260'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3214879366970595260'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2009/01/speed-up-mysql-query-cache-size.html' title='Speed Up Mysql query cache size'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-2638483379278917580</id><published>2008-12-18T03:23:00.000-08:00</published><updated>2008-12-18T03:24:53.279-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='PHP'/><title type='text'>addslashes  single quote and double quote</title><content type='html'>&amp;lt?php&lt;br /&gt;$old1 = 'H"s';&lt;br /&gt;$old2 = "H's";&lt;br /&gt;echo "new1 : " . addslashes  ($old1);&lt;br /&gt;echo "&lt;br&gt;";&lt;br /&gt;echo "new2 : " . addslashes  ($old2);&lt;br /&gt;? &amp;gt&lt;br /&gt; &lt;br /&gt;The output :&lt;br /&gt;new1 : H\"s&lt;br /&gt;new2 : H\'s&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-2638483379278917580?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/2638483379278917580/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=2638483379278917580' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2638483379278917580'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2638483379278917580'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/addslashes-single-quote-and-double.html' title='addslashes  single quote and double quote'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-2522727772889462391</id><published>2008-12-14T07:49:00.000-08:00</published><updated>2008-12-14T07:50:20.839-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='spanning tree'/><title type='text'>Spanning Tree Example</title><content type='html'>&lt;a href="http://www.cisco.com/warp/public/473/spanning_tree1.swf"&gt;http://www.cisco.com/warp/public/473/spanning_tree1.swf&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-2522727772889462391?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/2522727772889462391/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=2522727772889462391' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2522727772889462391'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2522727772889462391'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/spanning-tree-example.html' title='Spanning Tree Example'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-6597644905410060182</id><published>2008-12-14T05:15:00.000-08:00</published><updated>2008-12-14T05:21:00.369-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='C++'/><title type='text'>Finding prim number</title><content type='html'>&lt;pre&gt;&lt;br /&gt;#include &amp;lt stdio.h&amp;gt&lt;br /&gt;#include &amp;lt conio.h&amp;gt&lt;br /&gt;#include &amp;lt math.h&amp;gt&lt;br /&gt;main()&lt;br /&gt;{&lt;br /&gt;     int A,B,C=0,D;&lt;br /&gt;     printf("Program for finding Prime Number!\n\n\t you enter D=");&lt;br /&gt;     scanf("%d",&amp;amp;D);&lt;br /&gt;     printf("\nSo, prime number which is less than %d is...\n\n ",D);&lt;br /&gt;     printf("2\n");&lt;br /&gt;     for(A=3;A&lt;=D;A+=2)          {                         for(B=3;B&lt;=sqrt(A);B+=2)                            {if(A%B==0)                             break;}                         if(B&gt;sqrt(A))&lt;br /&gt;                        { printf("%d\n",A);&lt;br /&gt;                        C+=1;&lt;br /&gt;                         }&lt;br /&gt;                      &lt;br /&gt;        }&lt;br /&gt;   &lt;br /&gt;     printf("\n\n\t***There are %d.\n\n\n\r",C+1);&lt;br /&gt;    getch();&lt;br /&gt;}&lt;/math.h&gt;&lt;/conio.h&gt;&lt;/stdio.h&gt;&lt;br /&gt;&lt;/pre&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-6597644905410060182?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/6597644905410060182/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=6597644905410060182' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6597644905410060182'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6597644905410060182'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/finding-prim-number.html' title='Finding prim number'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-7179955910320764828</id><published>2008-12-14T01:09:00.001-08:00</published><updated>2008-12-14T01:14:47.030-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='design'/><category scheme='http://www.blogger.com/atom/ns#' term='examples'/><category scheme='http://www.blogger.com/atom/ns#' term='database'/><title type='text'>Relational Database Normalization Examples 7/7</title><content type='html'>&lt;b&gt;&lt;u&gt;ตัวอย่าง 5.1&lt;/u&gt; ตารางที่ยังไม่ทำ normalization&lt;/b&gt; (จากเอกสารของผู้ใช้ที่ส่งให้นักวิเคราะห์)&lt;br /&gt;เป็นตารางการสั่งซื้อ ให้ท่านลองนำไปทำ normalization&lt;br /&gt;&lt;table bg=""  align="center" border="0" cellpadding="4" cellspacing="4" style="color:black;"&gt; &lt;tbody&gt;&lt;tr bg=""  style="color:white;"&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;orderid&lt;br /&gt;301&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;orderdate&lt;br /&gt;15/12/46&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;productid&lt;br /&gt;401&lt;br /&gt;402&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;quan&lt;br /&gt;2&lt;br /&gt;5&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;tr bg=""  style="color:white;"&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;302&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;16/12/46&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;402&lt;br /&gt;405&lt;br /&gt;406&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;4&lt;br /&gt;4&lt;br /&gt;1&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;/tbody&gt;&lt;/table&gt;&lt;b&gt;&lt;u&gt;ตัวอย่าง 5.2&lt;/u&gt; ตารางที่ยังไม่ทำ normalization&lt;/b&gt; (จากเอกสารของผู้ใช้ที่ส่งให้นักวิเคราะห์)&lt;br /&gt;เป็นตารางเงินเดือน ให้ท่านลองนำไปทำ normalization&lt;br /&gt;&lt;table bg=""  align="center" border="0" cellpadding="4" cellspacing="4" style="color:black;"&gt; &lt;tbody&gt;&lt;tr bg=""  style="color:white;"&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;saleid&lt;br /&gt;101&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;salesalary&lt;br /&gt;2000&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;saleposition&lt;br /&gt;sale&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;custid&lt;br /&gt;201&lt;br /&gt;202&lt;br /&gt;203&lt;br /&gt;204&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;custname&lt;br /&gt;tom&lt;br /&gt;dang&lt;br /&gt;boy&lt;br /&gt;girl&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;/tbody&gt;&lt;/table&gt;&lt;b&gt;&lt;u&gt;ตัวอย่าง 5.3&lt;/u&gt; ใบเสร็จ 2 ใบ เลขที่ A0001 และ A0002&lt;/b&gt; (ให้ท่านลองนำไปทำ normalization)&lt;br /&gt;ตัวอย่างนี้ได้รับการเสนอแนะจาก sudomvon@minebea.co.th&lt;br /&gt;&lt;table bg=""  border="0" cellpadding="4" cellspacing="4" style="color:black;"&gt; &lt;tbody&gt;&lt;tr bg=""  style="color:white;"&gt;&lt;td&gt;&lt;pre&gt;&lt;span style="font-family:fixedsys;"&gt;                              Invoice No.:      A0001&lt;br /&gt;                            Date:        24/10/2004&lt;br /&gt;Sold to: ABC company&lt;br /&gt;Item                    Quantity    UnitPrice   Amount&lt;br /&gt;Pen                       50        3           150&lt;br /&gt;Book                     100        5           500&lt;br /&gt;Ruler                     20        2            40&lt;br /&gt;                                  Total       690&lt;br /&gt;&lt;/span&gt;&lt;hr  style="color:black;"&gt;&lt;br /&gt;&lt;span style="font-family:fixedsys;"&gt;                              Invoice No.:      A0002&lt;br /&gt;                            Date:       24/10/2004&lt;br /&gt;Sold to: XYZ company&lt;br /&gt;Item                    Quantity    UnitPrice   Amount&lt;br /&gt;Pen                     100         3           300&lt;br /&gt;Book                    120         5           600&lt;br /&gt;Ruler                    50         2           100&lt;br /&gt;                                  Total      1000&lt;br /&gt;&lt;/span&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;b&gt;&lt;u&gt;การทำ Normalization ของตัวอย่าง 5.3&lt;/u&gt; (ได้รับคำแนะนำจาก &lt;span style="color:red;"&gt;อ.อมรทิพย์ rung@yonok.ac.th&lt;/span&gt;)&lt;/b&gt;&lt;br /&gt;&lt;ul&gt;&lt;pre&gt;การเริ่มต้นทำ normalization ต้องนำข้อมูลมาสร้าง &lt;b&gt;ตารางเริ่มต้น&lt;/b&gt; ซึ่งเป็นขั้นตอนก่อนการทำ 1NF&lt;br /&gt;โดยไม่เขียน amount และ total เพราะเป็นค่าที่เกิดจากการคำนวณเท่านั้น&lt;br /&gt;&lt;span style="font-family:fixedsys;"&gt;&lt;u&gt;ตาราง temp&lt;/u&gt;&lt;br /&gt;A0001,24/10/2004,ABC  company,Pen,50,3&lt;br /&gt;A0001,24/10/2004,ABC  company,Book,100,5&lt;br /&gt;A0001,24/10/2004,ABC  company,Ruler,20,2&lt;br /&gt;A0002,24/10/2004,XYZ  company,Pen,100,3&lt;br /&gt;A0002,24/10/2004,XYZ  company,Book,120,5&lt;br /&gt;A0002,24/10/2004,XYZ  company,Ruler,50,2&lt;/span&gt;&lt;br /&gt;&lt;/pre&gt;&lt;/ul&gt;&lt;ul&gt;&lt;pre&gt;&lt;u&gt;&lt;b&gt;การทำ 1NF ของ ตัวอย่าง 5.3&lt;/b&gt;&lt;/u&gt;&lt;br /&gt;นำตารางเริ่มต้นมาจัดการเรื่อง multivalue เช่น คนชอบกินหลายอย่าง หรือการเพิ่ม key ประกอบข้อมูลที่อาจซ้ำ&lt;br /&gt;ตัวอย่างนี้เพิ่มรหัสลูกค้า และรหัสสินค้า เป็น key เพราะคิดว่า ชื่อลูกค้า และชื่อสินค้า อาจมีโอกาสซ้ำกันได้ และไม่เหมาะที่จะเป็น key&lt;span style="font-family:fixedsys;"&gt;&lt;br /&gt;ตาราง &lt;u&gt;tempoforder&lt;/u&gt;&lt;br /&gt;&lt;u&gt;A0001&lt;/u&gt;,24/10/2004,101,ABC  company,&lt;u&gt;201&lt;/u&gt;,Pen,50,3&lt;br /&gt;A0001,24/10/2004,101,ABC  company,202,Book,100,5&lt;br /&gt;A0001,24/10/2004,101,ABC  company,203,Ruler,20,2&lt;br /&gt;A0002,24/10/2004,102,XYZ  company,201,Pen,100,3&lt;br /&gt;A0002,24/10/2004,102,XYZ  company,202,Book,120,5&lt;br /&gt;A0002,24/10/2004,102,XYZ  company,203,Ruler,50,2&lt;br /&gt;&lt;/span&gt;&lt;/pre&gt;&lt;/ul&gt;&lt;span style="color: rgb(0, 128, 0);"&gt; &lt;/span&gt;&lt;ul&gt;&lt;pre&gt;&lt;span style="color: rgb(0, 128, 0);"&gt;&lt;u&gt;&lt;b&gt;การทำ 2NF ของ ตัวอย่าง 5.3&lt;/b&gt;&lt;/u&gt;&lt;br /&gt;แยกตาราง tempoforder เป็นหลายตาราง และทุกตารางมี primary key ที่มีการตรวจสอบการขึ้นตรงอย่างถูกต้อง&lt;span style="font-family:fixedsys;"&gt;&lt;br /&gt;&lt;span style=";font-family:ms sans serif;color:red;"  &gt;primay key คือ รหัสใบสั่งซื้อ&lt;/span&gt;&lt;br /&gt;ตาราง invoid_1&lt;br /&gt;&lt;u&gt;A0001&lt;/u&gt;,24/10/2004,101,ABC  company&lt;br /&gt;A0002,24/10/2004,102,XYZ  company&lt;br /&gt;&lt;span style=";font-family:ms sans serif;color:red;"  &gt;primay key คือ รหัสใบสั่งซื้อ และรหัสสินค้า&lt;/span&gt;&lt;br /&gt;ตาราง invoid_2&lt;br /&gt;&lt;u&gt;A0001,201&lt;/u&gt;,50,3&lt;br /&gt;A0001,202,100,5&lt;br /&gt;A0001,203,20,2&lt;br /&gt;A0002,201,100,3&lt;br /&gt;A0002,202,120,5&lt;br /&gt;A0002,203,50,2&lt;br /&gt;&lt;span style=";font-family:ms sans serif;color:red;"  &gt;ตาราง product เพราะราคาขึ้นกับรหัสสินค้า&lt;br /&gt;primary key คือ รหัสสินค้า&lt;/span&gt;&lt;br /&gt;ตาราง product&lt;br /&gt;&lt;u&gt;201&lt;/u&gt;,Pen,3&lt;br /&gt;202,Book,5&lt;br /&gt;203,Ruler,2&lt;br /&gt;&lt;/span&gt;&lt;br /&gt;&lt;/span&gt;&lt;/pre&gt;&lt;/ul&gt;&lt;span style="color: rgb(0, 0, 128);"&gt; &lt;/span&gt;&lt;ul&gt;&lt;pre&gt;&lt;span style="color: rgb(0, 0, 128);"&gt;&lt;u&gt;&lt;b&gt;การทำ 3NF ของ ตัวอย่าง 5.3&lt;/b&gt;&lt;/u&gt;&lt;span style="font-family:fixedsys;"&gt;&lt;br /&gt;&lt;span style=";font-family:ms sans serif;color:red;"  &gt;ตาราง invoid_1 เพราะชื่อลูกค้าไม่ขึ้นกับรหัสใบสั่งซื้อ จึงต้องแยกไปทำตาราง customer&lt;br /&gt;primay key คือ รหัสใบสั่งซื้อ&lt;/span&gt;&lt;br /&gt;ตาราง invoid_1&lt;br /&gt;&lt;u&gt;A0001&lt;/u&gt;,24/10/2004,101&lt;br /&gt;A0002,24/10/2004,102&lt;br /&gt;&lt;span style=";font-family:ms sans serif;color:red;"  &gt;ตาราง customer เพราะชื่อลูกค้าไม่ขึ้นกับ รหัสใบสั่งซื้อ แต่ขึ้นกับรหัสลูกค้า&lt;br /&gt;primay key คือ รหัสลูกค้า&lt;/span&gt;&lt;br /&gt;ตาราง customer&lt;br /&gt;&lt;u&gt;101&lt;/u&gt;,ABC  company&lt;br /&gt;102,XYZ  company&lt;br /&gt;&lt;span style=";font-family:ms sans serif;color:red;"  &gt;primay key คือ รหัสใบสั่งซื้อ และรหัสสินค้า เพราะ ปริมาณ และราคาต้องขึ้นกับ key 2 ตัวนี้&lt;/span&gt;&lt;br /&gt;ตาราง invoid_2&lt;br /&gt;&lt;u&gt;A0001,201&lt;/u&gt;,50,3&lt;br /&gt;A0001,202,100,5&lt;br /&gt;A0001,203,20,2&lt;br /&gt;A0002,201,100,3&lt;br /&gt;A0002,202,120,5&lt;br /&gt;A0002,203,50,2&lt;br /&gt;&lt;span style=";font-family:ms sans serif;color:red;"  &gt;ตาราง product เพราะราคาขึ้นกับรหัสสินค้า&lt;br /&gt;primary key คือ รหัสสินค้า&lt;/span&gt;&lt;br /&gt;ตาราง product&lt;br /&gt;&lt;u&gt;201&lt;/u&gt;,Pen,3&lt;br /&gt;202,Book,5&lt;br /&gt;203,Ruler,2&lt;br /&gt;&lt;/span&gt;&lt;br /&gt;&lt;/span&gt;&lt;/pre&gt;&lt;/ul&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-7179955910320764828?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/7179955910320764828/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=7179955910320764828' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/7179955910320764828'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/7179955910320764828'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/relational-database-normalization.html' title='Relational Database Normalization Examples 7/7'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-4529147160113594034</id><published>2008-12-14T01:07:00.000-08:00</published><updated>2008-12-14T01:14:27.435-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='design'/><category scheme='http://www.blogger.com/atom/ns#' term='database'/><title type='text'>Relational Database Normalization 6/7</title><content type='html'>&lt;b&gt;ขั้นตอนการ Normalization&lt;/b&gt;&lt;ul&gt;&lt;span style="color:blue;"&gt;5.1 เปลี่ยนตารางที่ยังไม่เคย Normalization เป็น First Normal Form หรือ 1NF&lt;/span&gt;&lt;dd&gt;วิธีพิจารณา คือ &lt;b&gt;แยกข้อมูลเป็นระเบียน โดยไม่มีการจัดกลุ่ม &lt;/b&gt; &lt;table width="80%" align="center"&gt;&lt;tbody&gt;&lt;tr&gt;&lt;td valign="top" align="center"&gt; &lt;table bg=""  border="0" cellpadding="4" cellspacing="1" style="color:black;"&gt; &lt;tbody&gt;&lt;tr bg=""  style="color:black;"&gt;&lt;td colspan="4"&gt;&lt;span style="color:white;"&gt;&lt;b&gt;ตารางที่ไม่ผ่านการ normalization&lt;/b&gt; &lt;/span&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr bg=""  style="color:white;"&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;orderid&lt;br /&gt;305&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;orderdate&lt;br /&gt;31/01/47&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;productid&lt;br /&gt;432&lt;br /&gt;455&lt;br /&gt;467&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;quan&lt;br /&gt;20&lt;br /&gt;2&lt;br /&gt;1&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;/tbody&gt;&lt;/table&gt; &lt;/td&gt;&lt;td valign="top"&gt; &lt;table bg="" style="color: rgb(0, 0, 128);" border="0" cellpadding="4" cellspacing="1"&gt; &lt;tbody&gt;&lt;tr bg=""  style="color:black;"&gt;&lt;td colspan="4"&gt;&lt;span style="color:white;"&gt;&lt;b&gt;ตารางที่ผ่านการ normalization ในระดับ 1NF&lt;/b&gt; &lt;/span&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr bg=""  style="color:white;"&gt;&lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;orderid&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;orderdate&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;productid&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;quan&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;tr bg=""  style="color:white;"&gt;&lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;305&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;31/01/47&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;432&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;20&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;tr bg=""  style="color:white;"&gt;&lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;305&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;31/01/47&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;455&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;2&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;tr bg=""  style="color:white;"&gt;&lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;305&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;31/01/47&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;467&lt;/span&gt;&lt;/td&gt; &lt;td valign="top"&gt;&lt;span style="font-family:fixedsys;"&gt;1&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt; &lt;/tbody&gt;&lt;/table&gt; &lt;/td&gt;&lt;/tr&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="color:blue;"&gt;5.2 เปลี่ยนจาก 1NF เป็น 2NF(Second Normal Form) คือการเปลี่ยนตารางที่มีปัญหา 4 ประการ&lt;/span&gt; &lt;/dd&gt;&lt;dd&gt;วิธีพิจารณาเปลี่ยน 1NF เป็น 2NF คือ &lt;b&gt;ไม่มี non key ตัวใด ไม่สัมพันธ์กับ primary key (ให้พิจารณาเฉพาะ non key และ primary key)&lt;/b&gt; &lt;/dd&gt;&lt;dd&gt;สิ่งที่ได้จากตาราง 1 ตาราง จะแตกออกมาเป็นหลายตาราง &lt;/dd&gt;&lt;dd&gt;   5.2.1 แก้ไขข้อมูล ต้องแก้หลายระเบียน &lt;/dd&gt;&lt;dd&gt;   5.2.2 มีข้อมูลเดียวกันในหลายระเบียน อาจขัดแย้งกันได้ &lt;/dd&gt;&lt;dd&gt;   5.2.3 การเพิ่มข้อมูลทำได้ยาก &lt;/dd&gt;&lt;dd&gt;   5.2.4 การลบข้อมูลทำได้ยาก&lt;br /&gt;ท่านลองพิจารณา Schema ของตารางนี้ว่าจะแยกได้กี่ตาราง&lt;br /&gt;จาก &lt;b&gt;orderid,custid,custname,date,proid,proname,price,quantity,categoryid,categoryname&lt;/b&gt;&lt;br /&gt;เป็น orders (orderid,custid,custname,date,proid,proname,price,quantity)&lt;br /&gt;เป็น categories (categoryid,categoryname)&lt;br /&gt;เหตุที่แยก categories ออกมา เพราะ categoryid ไม่สัมพันธ์กับ orderid แต่สัมพันธ์กับ proid โดยตรง จึงต้องแยกออกมา&lt;br /&gt;&lt;br /&gt;&lt;span style="color:blue;"&gt;5.3 เปลี่ยนจาก 2NF เป็น 3NF(Third Normal Form) คือแก้ปัญหายังไม่หมด อาจยังมีข้อมูลที่มีปัญหาอีก จึงต้องทำ 3NF&lt;/span&gt; &lt;/dd&gt;&lt;dd&gt;วิธีพิจารณาเปลี่ยน 2NF เป็น 3NF คือ &lt;b&gt;ไม่มี non key ตัวใด ขึ้นอยู่กับ non key ตัวอื่นใน entity เดียวกัน (ให้พิจารณาเฉพาะ non key และ non key)&lt;/b&gt;&lt;br /&gt;จาก &lt;b&gt;orders (orderid,custid,custname,date,proid,proname,price,quantity)&lt;/b&gt;&lt;br /&gt;เป็น orders (orderid,custid,date)&lt;br /&gt;เป็น customers (custid,custname)&lt;br /&gt;เป็น order details (orderid,proid,price,quantity)&lt;br /&gt;เป็น products (proid,proname) &lt;/dd&gt;&lt;/ul&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-4529147160113594034?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/4529147160113594034/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=4529147160113594034' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/4529147160113594034'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/4529147160113594034'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/relational-database-normalization-510.html' title='Relational Database Normalization 6/7'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-2778357676534713684</id><published>2008-12-14T01:06:00.001-08:00</published><updated>2008-12-14T01:15:28.382-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='design'/><category scheme='http://www.blogger.com/atom/ns#' term='database'/><title type='text'>Relational Database Design 5/7</title><content type='html'>&lt;ul&gt;&lt;b&gt;4. ขั้นตอนการเขียน ER model&lt;/b&gt;&lt;ul&gt;&lt;br /&gt;&lt;b&gt;4.1 กำหนด Entity type&lt;/b&gt; โดยกำหนดมาจากความต้องการของผู้ใช้ระบบ ว่าจะให้มี Entity สำหรับเก็บข้อมูลอะไรบ้าง &lt;ul&gt;&lt;br /&gt;เอนติตี้(Entity)  อาจเรียกว่า file หรือ table&lt;br /&gt;4.1.1 Strong entity คือเกิดขึ้นด้วยตนเองไม่ขึ้นกับ entity ใด เช่น &lt;span style="color:red;"&gt;นักศึกษา หรืออาจารย์ หรือสินค้า&lt;/span&gt; เป็นต้น&lt;br /&gt;4.1.2 Weak entity คือขึ้นโดยอาศัย entity อื่น เช่น &lt;span style="color:red;"&gt;เกรดเฉลี่ย ที่มาจากแฟ้มผลการเรียน หรือ แฟ้มลงทะเบียน หรือ แฟ้มสั่งซื้อ&lt;/span&gt; เป็นต้น &lt;dd&gt;:: สิ่งต่าง ๆ ที่ผู้ใช้งานฐานข้อมูลจะต้องยุ่งเกี่ยวด้วย เช่น คน แผนก ประเภท การสั่งซื้อ เป็นต้น &lt;/dd&gt;&lt;dd&gt;&lt;span style="color:blue;"&gt;Entities are the principal data object about which information is to be collected. Entities are usually recognizable concepts, either concrete or abstract, such as person, places, things, or events which have relevance to the database. Some specific examples of entities are EMPLOYEES, PROJECTS, INVOICES. An entity is analogous to a table in the relational model.&lt;/span&gt; &lt;/dd&gt;&lt;dd&gt;&lt;img src="http://www.thaiall.com/learn/sader11.gif" border="0" /&gt; &lt;/dd&gt;&lt;/ul&gt;&lt;br /&gt;&lt;b&gt;4.2 กำหนดความสัมพันธ์ (Relationship type)&lt;/b&gt; ที่เกิดขึ้นระหว่าง entity ในลักษณะของกริยา &lt;ul&gt;&lt;b&gt;ดีกรีของความสัมพันธ์(Degree of relation) มี 4 แบบ &lt;/b&gt;&lt;br /&gt;4.2.1 Unary relationship คือความสัมพันธ์ภายใน entity เดียวกัน เช่นแต่งงานของพนักงาน แต่ถ้ามีระดับแบบลูกน้อง หัวหน้าจะเรียก Recursive relationship(Unary)&lt;br /&gt;4.2.2 Binary relationship คือความสัมพันธ์แบบสอง entity&lt;br /&gt;4.2.3 Ternary relationship คือความสัมพันธ์แบบสาม entity&lt;br /&gt;4.2.4 Quaternary relationship คือความสัมพันธ์แบบสี่ entity&lt;br /&gt;&lt;img src="http://www.thaiall.com/learn/sader12.gif" border="0" /&gt;&lt;/ul&gt;&lt;br /&gt;&lt;b&gt;4.3 กำหนดแอททริบิวท์ (Attribute) ของแต่ละเอนติตี้&lt;/b&gt;&lt;ul&gt;&lt;dd&gt;:: แอททริบิวท์(Attibute) อาจเรียก field หรือ column คือ สิ่งที่ใช้อธิบายคุณสมบัติของเอนติตี้ เช่นคุณสมบัติของคน ก็มี รหัส ชื่อ อายุ เพศ เป็นต้น &lt;/dd&gt;&lt;dd&gt;Attributes describe the entity of which they are associated. A particular instance of an attribute is a value. For example, "Jane R. Hathaway" is one value of the attribute Name. The domainof an attribute is the collection of all possible values an attribute can have. The domain of Name is a character string.&lt;br /&gt;&lt;img src="http://www.thaiall.com/learn/sader01.gif" /&gt; &lt;/dd&gt;&lt;dd&gt;A key is the attribute or set of attributes which allow to identify each unique instance of an entity. So no two instances of an entity have or ever can have the same key value. These keys are called &lt;b&gt;candidate keys&lt;/b&gt;.  (รหัสนักศึกษา กับรหัสบัตรประชาชน) &lt;/dd&gt;&lt;dd&gt;Often we have different attributes or combinations of attributes which can serve as key. One key will be choosen and indicated as main key. It is called the &lt;b&gt;primary key&lt;/b&gt;. The other keys are the &lt;b&gt;alternate keys&lt;/b&gt;. The primary key is often the shortest possible and is the most unlikely to change. &lt;/dd&gt;&lt;dd&gt;The &lt;b&gt;primary key&lt;/b&gt; is indicated by underlining the name of attributes which form the primary key. In this case the attribute 'Code' has beed underlined. &lt;/dd&gt;&lt;dd&gt;The roof, body and trim of a same car can have different colors. The attribute 'color' is called a &lt;b&gt;multivalued attribute&lt;/b&gt;. This type of attribute is represented with a double line. (นักศึกษา 1 คนลงได้หลายวิชา) &lt;/dd&gt;&lt;dd&gt;The 'age' attribute, indicated with the slashed line, is a &lt;b&gt;derived attribute&lt;/b&gt;. It can be computed from the year and the present date. (เกรดเฉลี่ยของนักศึกษา)&lt;br /&gt;&lt;img src="http://www.thaiall.com/learn/sader03.gif" /&gt;&lt;br /&gt;&lt;img src="http://www.thaiall.com/learn/sader04.gif" /&gt; &lt;/dd&gt;&lt;dd&gt;&lt;u&gt;&lt;b&gt;คำต่าง ๆ ที่ควรทราบ&lt;/b&gt;&lt;/u&gt; &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;คีย์หลัก (Primary key)&lt;/b&gt; :: คีย์หลักประจำแฟ้ม &lt;ul&gt;&lt;ol&gt;&lt;b&gt;คุณสมบัติของคีย์หลัก&lt;/b&gt;&lt;li&gt;ข้อมูลของแอททริบิวท์มีความเป็นหนึ่งเดียว(Uniqueness) กล่าวคือทุก ๆ แถวของตารางจะต้องไม่มีข้อมูลของแอททริบิวท์ที่เป็นคีย์หลักซ้ำกันเลย &lt;/li&gt;&lt;li&gt;ต้องประกอบด้วยจำนวนแอททริบิวท์ที่น้อยที่สุด(Minimality) ที่จะสามารถใช้เจาะจง หรืออ้างอิงถึงแถวใดแถวหนึ่งในรีเลชันได้ &lt;/li&gt;&lt;/ol&gt;&lt;/ul&gt; &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;คีย์คู่แข่ง (Candidate key)&lt;/b&gt; :: คีย์ที่สามารถเป็น Primary key ได้ เช่น รหัสบัตรประชาชน หรือรหัสผู้เสียภาษี &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;คีย์สำรอง (Alternate key)&lt;/b&gt; :: คีย์ตัวอื่น ๆ ในตารางหลังจากเลือก primary key แล้ว &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;คีย์นอก (Foreign key)&lt;/b&gt; :: คีย์ตัวอื่น ๆ ในตารางหลังจากเลือก primary key แล้ว &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;คีย์ร่วม (Composite key)&lt;/b&gt; :: สามารถแยกออกไปได้อีก เช่น ที่อยู่ &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;Composite attibute&lt;/b&gt; :: สามารถแยกออกไปได้อีก เช่น ที่อยู่ &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;Atomic attibute&lt;/b&gt; :: ไม่สามารถแยกออกไปได้อีก เช่น นามสกุล &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;Multivalued attibute&lt;/b&gt; :: อาจมีหลายค่าได้ เช่น สีรถ &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;Derived attibute&lt;/b&gt; :: ไม่มีค่าแน่นอนของตน แต่ขึ้นกับค่าอื่น เช่นอายุ ขึ้นกับปีเกิด และปีปัจจุบัน &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;Entity type&lt;/b&gt; :: ชื่อของ entity เช่น &lt;b&gt;course&lt;/b&gt; (courseno,coursename) &lt;/dd&gt;&lt;dd&gt;- &lt;b&gt;Entity instance&lt;/b&gt; :: ค่าภายในของ entity เช่น &lt;b&gt;bcom101,Introduction to computer&lt;/b&gt; &lt;/dd&gt;&lt;/ul&gt;&lt;br /&gt;&lt;b&gt;4.4 คาร์ดินัลลิตี้ และปาร์ติซิเปชั่นของความสัมพันธ์ (Cardinality and participation of relationship)&lt;/b&gt;&lt;ul&gt;&lt;b&gt;4.4.1 คาร์ดินัลลิตี้ของความสัมพันธ์(Cardinality of Relationship)&lt;/b&gt;&lt;ol&gt;:: แต่ละเอนติตี้มีความสัมพันธ์ต่อกัน โดยมีคำกริยามาเชื่อมระหว่างแต่ละเอนติตี้ &lt;li&gt;One-to-one relationship ความสัมพันธ์แบบ 1 ต่อ 1 &lt;dd&gt;เช่น คนขับกับรถ หรือครูใหญ่กับโรงเรียน เป็นต้น &lt;/dd&gt;&lt;/li&gt;&lt;li&gt;One-to-many relationship ความสัมพันธ์แบบ 1 ต่อหลายข้อมูล &lt;dd&gt;เช่น ลูกค้ากับหมายเลขโทรศัพท์มือถือ หรือ อาจารย์ที่ปรึกษากับนักเรียน &lt;/dd&gt;&lt;/li&gt;&lt;li&gt;Many-to-many relationship ความสัมพันธ์แบบหลายข้อมูล ต่อหลายข้อมูล &lt;dd&gt;เช่น นักเรียนกับวิชาที่ลงทะเบียน หรือ คนงานกับโครงการสร้างบ้าน&lt;br /&gt;&lt;img src="http://www.thaiall.com/learn/sader02.gif" /&gt; &lt;/dd&gt;&lt;/li&gt;&lt;/ol&gt;&lt;br /&gt;&lt;b&gt;4.4.2 ปาร์ติซิเปชั่นของความสัมพันธ์ (Participation of relationship)&lt;/b&gt;&lt;dd&gt;:: ความสัมพันธ์ระหว่าง entity &lt;/dd&gt;&lt;dd&gt;1. Total หรือ Mandatory participation (ต้องมี จะใช้เส้นคู่) &lt;/dd&gt;&lt;dd&gt;2. Partial หรือ Optional participation (เลือกได้ จะใช้เส้นเดียว) &lt;/dd&gt;&lt;/ul&gt;&lt;/ul&gt;&lt;/ul&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-2778357676534713684?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/2778357676534713684/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=2778357676534713684' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2778357676534713684'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2778357676534713684'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/relational-database-design-410.html' title='Relational Database Design 5/7'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-6612857977627037116</id><published>2008-12-14T01:05:00.001-08:00</published><updated>2008-12-14T01:15:38.271-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='design'/><category scheme='http://www.blogger.com/atom/ns#' term='database'/><title type='text'>Relational Database ER Model 4/7</title><content type='html'>3. ER model (Entity-Relationship Model)&lt;br /&gt;             :: เสนอครั้งแรกโดย ปีเตอร์(Chen,1976 - 2519) เป็นเครื่องมือนำเสนอโครงสร้างของฐานข้อมูลใน ระดับความคิด(Conceptual level) ออกมาในลักษณะของแผนภาพ(Diagram) ที่ง่ายต่อความเข้าใจ เพื่อสื่อความหมายระหว่างนักออกแบบฐานข้อมูล และผู้ใช้ เกี่ยวกับ ความสัมพันธ์ของเอนติตี้(Entity) กับเอนติตี้(Entity) และเอนติตี้(Entity) กับ แอททริบิวท์(Attibute)&lt;br /&gt;             From: http://www.utexas.edu/cc/database/datamodeling/dm/erintro.html&lt;br /&gt;             The Entity-Relationship (ER) model was originally proposed by Peter in 1976 [Chen76] as a way to unify the network and relational database views. Simply stated the ER model is a conceptual data model that views the real world as entities and relationships. A basic component of the model is the Entity-Relationship diagram which is used to visually represents data objects. Since Chen wrote his paper the model has been extended and today it is commonly used for database design For the database designer, the utility of the ER model is:&lt;br /&gt;             - It maps well to the relational model. The constructs used in the ER model can easily be transformed into relational tables.&lt;br /&gt;             - It is simple and easy to understand with a minimum of training. Therefore, the model can be used by the database designer to communicate the design to the end user.&lt;br /&gt;             - In addition, the model can be used as a design plan by the database developer to implement a data model in a specific database management software.&lt;br /&gt;&lt;br /&gt;             From: http://itprojmngt.8m.net/softdev/analysis/erd/erd.html&lt;br /&gt;             The goal of Entity Relationship Modeling Technique is to discover and represent the relations between groups of information elements. The method will list the information which is essential for the application and/or organization, structure and describe this information. The results will serve to design the databases. The resulting drawing is never finished. It will evolve together with the information which is managed by the application or/and which serves the business purposes.&lt;br /&gt;&lt;br /&gt;             ส่วนประกอบของ ER model&lt;br /&gt;             - เอ็นติตี้ (Entity)&lt;br /&gt;             - แอททริบิวท์ (Attribute)&lt;br /&gt;             - ความสัมพันธ์ระหว่างเอ็นติตี้ (Relationship)&lt;br /&gt;             - ดีกรีของความสัมพันธ์ (Degree of a relation)&lt;br /&gt;&lt;br /&gt;             ขั้นตอนการเขียน ER model&lt;br /&gt;             3.1 สร้าง entity ขึ้นมาจากความต้องการของผู้ใช้&lt;br /&gt;             3.2 สร้างความสัมพันธ์(Relation) ระหว่าง entity&lt;br /&gt;             3.3 พิจารณา key ของแต่ละ entity&lt;br /&gt;             3.4 พิจารณาคุณสมบัติของ entity แต่ละตัว&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-6612857977627037116?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/6612857977627037116/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=6612857977627037116' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6612857977627037116'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6612857977627037116'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/relational-database-er-model.html' title='Relational Database ER Model 4/7'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-3638360371340427733</id><published>2008-12-14T01:04:00.000-08:00</published><updated>2008-12-14T01:16:04.440-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='design'/><category scheme='http://www.blogger.com/atom/ns#' term='database'/><title type='text'>Relational Database Design 3/7</title><content type='html'>2. ขั้นตอนเกี่ยวกับการออกแบบฐานข้อมูล&lt;br /&gt;       2.1 เปลี่ยนความต้องการของผู้ใช้เป็น ER model หรือ Relational model&lt;br /&gt;          2.1.1 โมเดลแบบ ER model (Entity-Relationship Model)&lt;br /&gt;          - เอ็นติตี้ (Entity)&lt;br /&gt;          - แอททริบิวท์ (Attribute)&lt;br /&gt;          - ความสัมพันธ์ระหว่างเอ็นติตี้ (Relationship)&lt;br /&gt;          - ดีกรีของความสัมพันธ์ (Degree of a relation)&lt;br /&gt;          2.1.2 โมเดลเชิงสัมพันธ์ (Relational model)&lt;br /&gt;          - รีเลชัน (Relation) หรือ Table หรือ file&lt;br /&gt;          - ทูเพิล (Tuple) หรือ Row หรือ Record&lt;br /&gt;          - แอททริบิวท์ (Attribute) หรือ Column หรือ Field&lt;br /&gt;       2.2 การทำนอร์มัลไลซ์ (Normalization)&lt;br /&gt;       2.3 กำหนดคุณสมบัติของเขตข้อมูลแต่ละตัว&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-3638360371340427733?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/3638360371340427733/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=3638360371340427733' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3638360371340427733'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3638360371340427733'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/relational-database-design-210.html' title='Relational Database Design 3/7'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-6778463968342879498</id><published>2008-12-14T01:03:00.000-08:00</published><updated>2008-12-14T01:16:21.520-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='design'/><category scheme='http://www.blogger.com/atom/ns#' term='database'/><title type='text'>Relational Databse Schema Example 2/7</title><content type='html'>&lt;b&gt;ตัวอย่างของ Relation schema ของ &lt;/b&gt; &lt;span style="font-size:6;"&gt;Northwind&lt;/span&gt; &lt;ol&gt;&lt;li&gt;&lt;b&gt;Categories&lt;/b&gt; (&lt;u&gt;CategoryID&lt;/u&gt;,CategoryName,Description,Picture) &lt;/li&gt;&lt;li&gt;&lt;b&gt;Customers&lt;/b&gt; (&lt;u&gt;CustomerID&lt;/u&gt;,CompanyName,ContactName,ContactTitle,Address,City,Region,PostalCode,Country,Phone,Fax) &lt;/li&gt;&lt;li&gt;&lt;b&gt;Employees&lt;/b&gt; (&lt;u&gt;EmployeeID&lt;/u&gt;,LastName,FirstName,Title,BirthDate,HireDate,Address,City,Region,PostalCode,Country,HomePhone,Extension,Photo,Notes,ReportsTo) &lt;/li&gt;&lt;li&gt;&lt;b&gt;Products&lt;/b&gt; (&lt;u&gt;ProductID&lt;/u&gt;,ProductName,SupplierID,CategoryID,QuantityPerUnit,UnitPrice,UnitsInStock,UnitsOnOrder,ReorderLevel,Discontinued) &lt;/li&gt;&lt;li&gt;&lt;b&gt;Shippers&lt;/b&gt; (&lt;u&gt;ShipperID&lt;/u&gt;,CompanyName,Phone) &lt;/li&gt;&lt;li&gt;&lt;b&gt;Suppliers&lt;/b&gt; (&lt;u&gt;SupplierID&lt;/u&gt;,CompanyName,ContactName,ContactTitle,Address,City,Region,PostalCode,Country,Phone,Fax,Homepage) &lt;/li&gt;&lt;li&gt;&lt;b&gt;Orders&lt;/b&gt; (&lt;u&gt;OrderID&lt;/u&gt;,CustomerID,EmployeeID,OrderDate,RequiredDate,ShippedDate,ShipVia,Freight,ShipName,ShipAddress,ShipCity,ShipRegion,ShipPostalCode,ShipCountry) &lt;/li&gt;&lt;li&gt;&lt;b&gt;Order Details&lt;/b&gt; (&lt;u&gt;OrderID&lt;/u&gt;,ProductID,UnitPrice,Quantity,Discount)&lt;br /&gt;&lt;br /&gt;&lt;b&gt;ตารางข้างล่างนี้คือ ตารางแสดงความสัมพันธ์ที่ใช้โปรแกรม Microsoft access สร้างขึ้น&lt;/b&gt;&lt;br /&gt;&lt;img src="http://www.thaiall.com/learn/sader06.gif" /&gt; &lt;/li&gt;&lt;/ol&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-6778463968342879498?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/6778463968342879498/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=6778463968342879498' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6778463968342879498'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6778463968342879498'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/relational-databse-schema-example-210.html' title='Relational Databse Schema Example 2/7'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-3353098243149408324</id><published>2008-12-14T01:01:00.000-08:00</published><updated>2008-12-14T01:16:47.829-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='design'/><category scheme='http://www.blogger.com/atom/ns#' term='database'/><title type='text'>Relational Database Design 1/7</title><content type='html'>&lt;ul&gt;&lt;b&gt;สถาปัตยกรรมฐานข้อมูล(Database architecture) 3 ระดับ&lt;/b&gt;(Three-level architecture) :: &lt;dd&gt;&lt;span style="color:blue;"&gt;1.1 ระดับภายนอก (External level)&lt;/span&gt; &lt;ul&gt;&lt;dd&gt;มาจากแบบฟอร์มเอกสาร ว่ามีอะไรในเอกสารบ้าง หรือจากผู้ใช้ที่แต่ละคน &lt;/dd&gt;&lt;dd&gt;เป็นการรวบรวมข้อมูลอย่างง่าย ๆ จากผู้ใช้ เพื่อให้กับนักวิเคราะห์นำไปศึกษา &lt;/dd&gt;&lt;dd&gt;ผู้ใช้คนที่หนึ่ง : (&lt;b&gt;รหัส, ชื่อ&lt;/b&gt;) &lt;/dd&gt;&lt;dd&gt;ผู้ใช้คนที่สอง : (&lt;b&gt;รหัส, ที่อยู่&lt;/b&gt;)&lt;/dd&gt;&lt;/ul&gt; &lt;/dd&gt;&lt;dd&gt;&lt;span style="color:blue;"&gt;1.2 ระดับความคิด (Conceptual level)&lt;/span&gt; &lt;ul&gt;&lt;dd&gt;ตีความออกมาเป็นตารางโดยนำแบบฟอร์มต่าง ๆ มารวมกัน เพื่อแสดงความต้องการของผู้ใช้ในรูปที่สมบูรณ์ &lt;/dd&gt;&lt;dd&gt;อาจมีการวิเคราะห์ และออกแบบโดยผ่านขั้นตอนมากมาย ทั้ง E-R หรือ Normalization จนเสร็จสิ้น &lt;/dd&gt;&lt;dd&gt;&lt;b&gt;พนักงาน (รหัส, ชื่อ, ที่อยู่)&lt;/b&gt; ในแบบสคีมา(Schema)&lt;/dd&gt;&lt;dd&gt;หรือ&lt;/dd&gt;&lt;dd&gt;&lt;b&gt;person (id, name, address)&lt;/b&gt; ในแบบสคีมา(Schema)&lt;/dd&gt;&lt;/ul&gt; &lt;/dd&gt;&lt;dd&gt;&lt;span style="color:blue;"&gt;1.3 ระดับภายใน (Internal level)&lt;/span&gt; &lt;ul&gt;&lt;dd&gt;ตีความในระดับการจัดเก็บข้อมูลจริง เป็นหน้าที่ของผู้ออกแบบอย่างแท้จริง &lt;/dd&gt;&lt;dd&gt;&lt;b&gt;struct person{ &lt;/b&gt;&lt;/dd&gt;&lt;dd&gt;&lt;b&gt;  int id; &lt;/b&gt;&lt;/dd&gt;&lt;dd&gt;&lt;b&gt;  char name[20]; &lt;/b&gt;&lt;/dd&gt;&lt;dd&gt;&lt;b&gt;  char address[20] &lt;/b&gt;&lt;/dd&gt;&lt;dd&gt;&lt;b&gt;} index id;&lt;/b&gt;&lt;/dd&gt;&lt;/ul&gt;&lt;/dd&gt;&lt;dt&gt;source : http://www.thaiall.com&lt;br /&gt;&lt;/dt&gt;&lt;/ul&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-3353098243149408324?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/3353098243149408324/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=3353098243149408324' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3353098243149408324'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3353098243149408324'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/relational-database-design.html' title='Relational Database Design 1/7'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-6876235049858002860</id><published>2008-12-03T07:52:00.000-08:00</published><updated>2008-12-03T07:53:35.533-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='ResearchURL'/><title type='text'>Education Resources Information Center</title><content type='html'>&lt;a href="http://eric.ed.gov/"&gt;http://eric.ed.gov/&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;E&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-6876235049858002860?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/6876235049858002860/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=6876235049858002860' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6876235049858002860'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/6876235049858002860'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/education-resources-information-center.html' title='Education Resources Information Center'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-5473847618232135838</id><published>2008-12-02T05:37:00.000-08:00</published><updated>2008-12-02T05:39:20.996-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='vista'/><title type='text'>วิธีแสดงภาษาไทย บน command prompt vista</title><content type='html'>&lt;table id="table1" width="100%" border="0" cellspacing="1"&gt;&lt;tbody&gt;&lt;tr&gt;&lt;td&gt;&lt;span class="styleorange"&gt;&lt;&lt; การตั้งค่าให้ดอสพร็อมพ์ในวินโดวส์ 2000/XP/2003 ให้ใช้ภาษาไทยได้ &gt;&gt;&lt;/span&gt;&lt;/td&gt;        &lt;/tr&gt;        &lt;tr&gt;         &lt;td&gt;&lt;span class="style2"&gt;         &lt;span class="style13"  style="color:#000080;"&gt;เขียนโดย คุณ ทัชชี่                        &lt;/span&gt;&lt;/span&gt;&lt;/td&gt;        &lt;/tr&gt;        &lt;tr&gt;         &lt;td&gt; &lt;/td&gt;        &lt;/tr&gt;        &lt;tr&gt;                               &lt;td class="style13"&gt;&lt;span class="style2"&gt; โดยปกติแล้ว  เราจะไม่สามารถใช้ภาษาไทยใน DOS BOX บนวินโดวส์ 2000 ขึ้นไป  ไม่ได้เลย  อ่านก็ไม่ได้  เขียนแล้วก็อ่านไม่รู้เรื่อง  จะเปลี่ยนฟอนต์เป็นฟอนต์ที่มีภาษาไทยก็ไม่ได้อีก  ดังนั้นมันต้องมีอะไรแน่ๆครับ&lt;br /&gt;                             &lt;br /&gt;ผมเคยไปอ่านเจอวิธีแก้ปัญหานี้ใน Technet ของ Microsoft  แต่มันเป็นวิธีแก้ปัญหาของคนในประเทศอื่นๆที่ไม่ได้มีลักษณะภาษาแบบภาษาไทย  (ที่มันต้องมีสระบนสระล่างนี่แหล่ะครับ)  ซึ่งลักษณะการแก้ปัญหาก็คล้ายๆกัน  ผมจึงได้ลองประยุกต์ใช้ดู&lt;br /&gt;                             &lt;br /&gt;                              ปกติเราจะเห็นดอสของวินโดวส์ 2000/XP หน้าตาเป็นแบบนี้&lt;br /&gt;                             &lt;br /&gt;                              &lt;img src="http://justusers.net/articles/others/thaidosxp/image01.png" width="358" border="0" height="126" /&gt;&lt;br /&gt;                             &lt;br /&gt;    แล้วเราต้องการเปลี่ยนเป็นแบบนี้&lt;br /&gt;   &lt;br /&gt;    &lt;img src="http://justusers.net/articles/others/thaidosxp/image02.png" width="381" border="0" height="157" /&gt;&lt;br /&gt;   &lt;br /&gt;   &lt;br /&gt;    ผมมี 2 ตัวเลือกให้คุณเลือก  คือ&lt;br /&gt;    1)  สำหรับมือใหม่&lt;br /&gt;    2)  สำหรับมือเก่า&lt;br /&gt;   &lt;br /&gt;   &lt;br /&gt;    1. มือใหม่อ่านที่นี่ครับ  ส่วนมือเก่า  ข้ามไปอ่านหัวข้อถัดไปได้เลยครับ&lt;br /&gt;   &lt;br /&gt;    1.1 ก่อนอื่นไปดาวน์โหลดไฟล์นี้มาก่อนครับ&lt;br /&gt;   &lt;br /&gt;&lt;a href="http://www.thaikore.com/forum/index.php?act=attach&amp;amp;type=post&amp;amp;id=609"&gt;      &lt;span style="text-decoration: underline;"&gt;http://www.thaikore.com/forum/index.php?act=attach&amp;amp;type=post&amp;amp;id=609&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;   &lt;br /&gt;    แล้วก็มาแตกไฟล์ (Unzip) จะเห็นได้ว่ามีไฟล์ทั้งหมด 4 ไฟล์  ตามภาพนะครับ&lt;br /&gt;                             &lt;br /&gt;                              &lt;img src="http://justusers.net/articles/others/thaidosxp/image03.png" width="206" border="0" height="109" /&gt;&lt;br /&gt;                             &lt;br /&gt;    1.2 ให้ติดตั้งฟอนต์ Courier MonoThai ดังนี้&lt;br /&gt;   &lt;br /&gt;    - คลิก Start &gt;&gt; Run แล้วพิมพ์ในช่องว่า fonts&lt;br /&gt;    - คลิกที่ไฟล์ &lt;b&gt;courmon.ttf&lt;/b&gt;  แล้วลากมาใส่โฟลเดอร์ fonts&lt;br /&gt;   &lt;br /&gt;    1.3 ดับเบิลคลิกไฟล์ Registry ทั้ง 3 ไฟล์  เพื่อ Import เข้าไปใน Registry ของระบบ&lt;br /&gt;                             &lt;br /&gt;    1.4 Restart เครื่อง 1 ครั้ง&lt;br /&gt;   &lt;br /&gt;    1.5 คลิก &lt;b&gt;Start &gt;&gt; Programs &gt;&gt; Accessories &gt;&gt;  Command Prompt&lt;/b&gt;  แล้วคลิกตามภาพนี้&lt;br /&gt;   &lt;br /&gt;    &lt;img src="http://justusers.net/articles/others/thaidosxp/image09.jpg" width="502" border="0" height="404" /&gt;&lt;br /&gt;   &lt;br /&gt;    1.6 จากในภาพ  ผมแนะนำให้ตั้งค่าขนาดฟอนต์เป็นขนาด 18 – 20 นะครับ  เพื่อความคมชัด&lt;br /&gt;                             &lt;br /&gt;    1.7 หลังจากนั้นก็ลองใช้ดูได้เลยครับ&lt;br /&gt;   &lt;br /&gt;   &lt;br /&gt;    2. สำหรับมือเก่าอ่านตรงนี้ครับ&lt;br /&gt;   &lt;br /&gt;    2.1 ดาวน์โหลดไฟล์ในข้อ 1.1 มานะครับ  แล้วติดตั้งฟอนต์ให้เรียบร้อย&lt;br /&gt;   &lt;br /&gt;    2.2 สั่งรันโปรแกรม &lt;b&gt;regedit.exe&lt;/b&gt;  แล้วเข้าไปแก้ไขในส่วนต่างๆ ดังนี้&lt;br /&gt;   &lt;br /&gt;    &lt;span style="color:#0000ff;"&gt;&lt;b&gt; HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Console\Nls&lt;/b&gt;&lt;/span&gt;  ให้เพิ่มข้อมูลชนิด String ชื่อ "&lt;span style="color:#0000ff;"&gt;&lt;b&gt;0000041e&lt;/b&gt;&lt;/span&gt;"&lt;br /&gt;                             &lt;br /&gt;                              &lt;b&gt;&lt;span style="color:#0000ff;"&gt; HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Console\TrueTypeFont&lt;/span&gt;  &lt;/b&gt;ให้เพิ่มข้อมูลชนิด String ชื่อ "&lt;b&gt;874&lt;/b&gt;"  มีข้อมูลภายในคือ "&lt;span style="color:#0000ff;"&gt;&lt;b&gt;Courier MonoThai&lt;/b&gt;&lt;/span&gt;"&lt;br /&gt;                             &lt;br /&gt;                              &lt;span style="color:#0000ff;"&gt;&lt;b&gt; HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\MS-DOS Emulation\Font&lt;/b&gt;&lt;/span&gt;  ให้เปลี่ยนข้อมูลชนิด String ที่ชื่อ "&lt;b&gt;font&lt;/b&gt;" ให้เป็น "&lt;span style="color:#0000ff;"&gt;&lt;b&gt;Courier MonoThai&lt;/b&gt;&lt;/span&gt;"&lt;br /&gt;                             &lt;br /&gt;                              &lt;span style="color:#0000ff;"&gt;&lt;b&gt; HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Keyboard Layout\DosKeybCodes&lt;/b&gt;&lt;/span&gt;  ให้เพิ่มข้อมูลชนิด String ชื่อต่อไปนี้&lt;br /&gt;                             &lt;br /&gt;"&lt;span style="color:#0000ff;"&gt;&lt;b&gt;0000041E&lt;/b&gt;&lt;/span&gt;"  มีข้อมูลภายในเป็น "&lt;b&gt;th&lt;/b&gt;"&lt;br /&gt;   &lt;br /&gt;"&lt;span style="color:#0000ff;"&gt;&lt;b&gt;0001041E&lt;/b&gt;&lt;/span&gt;"  มีข้อมูลภายในเป็น "&lt;b&gt;th&lt;/b&gt;"&lt;br /&gt;   &lt;br /&gt;"&lt;span style="color:#0000ff;"&gt;&lt;b&gt;0002041E&lt;/b&gt;&lt;/span&gt;"  มีข้อมูลภายในเป็น "&lt;b&gt;th&lt;/b&gt;"&lt;br /&gt;   &lt;br /&gt;"&lt;span style="color:#0000ff;"&gt;&lt;b&gt;0003041E&lt;/b&gt;&lt;/span&gt;"  มีข้อมูลภายในเป็น "&lt;b&gt;th&lt;/b&gt;"&lt;br /&gt;   &lt;br /&gt;    2.3 สั่ง Restart เครื่อง 1 ครั้ง&lt;br /&gt;                             &lt;br /&gt;    2.4 เข้ามากำหนดค่าต่างๆตามรูป 1.5 ครับ&lt;br /&gt;   &lt;br /&gt;    2.5 ทีนี้ก็จะสามารถใช้งานได้แล้วครับ&lt;/span&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-5473847618232135838?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/5473847618232135838/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=5473847618232135838' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/5473847618232135838'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/5473847618232135838'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/12/command-prompt-vista.html' title='วิธีแสดงภาษาไทย บน command prompt vista'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-2199060251805172768</id><published>2008-11-25T08:13:00.000-08:00</published><updated>2008-11-25T08:50:28.378-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='Labs'/><category scheme='http://www.blogger.com/atom/ns#' term='cisco'/><category scheme='http://www.blogger.com/atom/ns#' term='datacom'/><category scheme='http://www.blogger.com/atom/ns#' term='switch'/><title type='text'>Config switch vtp mode</title><content type='html'>สวัสดีครับ เทอมนี้ได้เรียน datacom 2 เป็นเรื่องเครือข่าย โดยเฉพาะ Lab ได้ config siwtch , router....&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;เข้าเรื่องกันเลยดีกว่าครับ&lt;br /&gt;&lt;br /&gt;สำหรับการทำ vtp บน switch การทดลองนี้ผมใช้ CCNA Network Visualizer&lt;br /&gt;ก่อนอื่นก็ทำการเชื่อมต่อ switch และ host แล้วกำหนด IP ให้กับ host  ดังรูป&lt;br /&gt;ในการทดลองนี้ผมให้&lt;br /&gt;vlan1 ip 127.2.145.0&lt;br /&gt;vlan2 ip 192.2.146.0&lt;br /&gt;&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://3.bp.blogspot.com/_kES3xlANtrU/SSwonoqWg2I/AAAAAAAAAPg/LZJsKCBIWOs/s1600-h/lab2.jpg"&gt;&lt;img style="margin: 0px auto 10px; display: block; text-align: center; cursor: pointer; width: 544px; height: 367px;" src="http://3.bp.blogspot.com/_kES3xlANtrU/SSwonoqWg2I/AAAAAAAAAPg/LZJsKCBIWOs/s400/lab2.jpg" alt="" id="BLOGGER_PHOTO_ID_5272633925139071842" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;เสร็จแล้วก็จะทำการ แบ่ง vlan บน switch ทั้งสองตัวกัน&lt;br /&gt;โดยตัวแรก ก็จะมี 2 vlan  ตัวที่ 2 ก็จะมี 2 vlan เช่นกัน&lt;br /&gt;โดยใช้คำสั่งต่อไปนี้&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;switch Con0 is now available&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Press RETURN to get started!&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;switch&gt;enable&lt;br /&gt;switch#vlan database&lt;br /&gt;switch(vlan)#vlan 2 name VLAN1&lt;br /&gt;VLAN 2 modified:&lt;br /&gt;   Name: VLAN1&lt;br /&gt;switch(vlan)#vlan 2 name VLAN2&lt;br /&gt;VLAN 2 modified:&lt;br /&gt;   Name: VLAN2&lt;br /&gt;switch(vlan)#exit&lt;br /&gt;APPLY completed.&lt;br /&gt;Exiting....&lt;br /&gt;switch#&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;ที่นี้ก็ลอง แสดง vlan ที่เราสร้างไว้&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;switch Con0 is now available&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Press RETURN to get started!&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;switch&gt;enable&lt;br /&gt;switch#vlan database&lt;br /&gt;switch(vlan)#vlan 2 name VLAN1&lt;br /&gt;VLAN 2 modified:&lt;br /&gt;   Name: VLAN1&lt;br /&gt;switch(vlan)#vlan 2 name VLAN2&lt;br /&gt;VLAN 2 modified:&lt;br /&gt;   Name: VLAN2&lt;br /&gt;switch(vlan)#end&lt;br /&gt;             ^&lt;br /&gt;% Invalid input detected at '^' marker.&lt;br /&gt;switch(vlan)#exit&lt;br /&gt;APPLY completed.&lt;br /&gt;Exiting....&lt;br /&gt;switch#config t&lt;br /&gt;Enter configuration commands, one per line.  End with CNTL/Z&lt;br /&gt;switch(config)#vtp ?&lt;br /&gt; domain     Set the name of the VTP administrative domain.&lt;br /&gt; file       Configure IFS filesystem file where VTP configuration is stored.&lt;br /&gt; interface  Configure interface as the preferred source for the VTP IP updater&lt;br /&gt;            address.&lt;br /&gt; mode       Configure VTP device mode&lt;br /&gt; password   Set the password for the VTP administrative domain&lt;br /&gt; pruning    Set the adminstrative domain to permit pruning&lt;br /&gt; version    Set the adminstrative domain to VTP version&lt;br /&gt;&lt;br /&gt;switch(config)#vtp ?&lt;br /&gt; domain     Set the name of the VTP administrative domain.&lt;br /&gt; file       Configure IFS filesystem file where VTP configuration is stored.&lt;br /&gt; interface  Configure interface as the preferred source for the VTP IP updater&lt;br /&gt;            address.&lt;br /&gt; mode       Configure VTP device mode&lt;br /&gt; password   Set the password for the VTP administrative domain&lt;br /&gt; pruning    Set the adminstrative domain to permit pruning&lt;br /&gt; version    Set the adminstrative domain to VTP version&lt;br /&gt;&lt;br /&gt;switch(config)#vtp mode server&lt;br /&gt;Device mode already VTP SERVER.&lt;br /&gt;switch(config)#exit&lt;br /&gt;switch#sh vlan&lt;br /&gt;&lt;br /&gt;VLAN Name                             Status    Ports&lt;br /&gt;---- -------------------------------- --------- -------------------------------&lt;br /&gt;1    default                          active    Fa0/1, Fa0/2,Fa0/3, Fa0/4, Fa0/5, Fa0/6&lt;br /&gt;                                               Fa0/7, Fa0/8, Fa0/9, Fa0/10&lt;br /&gt;                                               Fa0/11, Fa0/12&lt;br /&gt;2    VLAN2                            active  &lt;br /&gt;3    vlan2                            active  &lt;br /&gt;1002 fddi-default                     active&lt;br /&gt;1003 token-ring-default               active&lt;br /&gt;1004 fddinet-default                  active&lt;br /&gt;1005 trnet-default                    active&lt;br /&gt;&lt;br /&gt;VLAN Type  SAID       MTU   Parent RingNo BridgeNo Stp  BrdgMode Trans1 Trans2&lt;br /&gt;---- ----- ---------- ----- ------ ------ -------- ---- -------- ------ ------&lt;br /&gt;1    enet  100001     1500  -      -      -        -    -        0      0&lt;br /&gt;2    enet  100002     1500  -      -      -        -    -        0      0&lt;br /&gt;3    enet  100003     1500  -      -      -        -    -        0      0&lt;br /&gt;1002 fddi  101002     1500  -      -      -        -    -        0      0&lt;br /&gt;1003 tr    101003     1500  -      -      -        -    -        0      0&lt;br /&gt;1004 fdnet 101004     1500  -      -      -        ieee -        0      0&lt;br /&gt;1005 trnet 101005     1500  -      -      -        ibm  -        0      0&lt;br /&gt;&lt;br /&gt;Remote SPAN VLANs&lt;br /&gt;------------------------------------------------------------------------------&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Primary Secondary Type              Ports&lt;br /&gt;------- --------- ----------------- ------------------------------------------&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;switch#&lt;br /&gt;&lt;br /&gt;เพิ่ม port เข้าไปใน แต่ละ vlan&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;switch(config)#interface fastethernet 0/1&lt;br /&gt;switch(config-if)#switchport mode access&lt;br /&gt;switch(config-if)#switchport access vlan  2&lt;br /&gt;switch(config-if)#exit&lt;br /&gt;switch(config)#interface fastethernet 0/2&lt;br /&gt;switch(config-if)#switchport mode access&lt;br /&gt;switch(config-if)#switchport access vlan  2&lt;br /&gt;switch(config-if)#exit&lt;br /&gt;switch(config)#interface fastethernet 0/3&lt;br /&gt;switch(config-if)#switchport mode access&lt;br /&gt;switch(config-if)#switchport access vlan  3&lt;br /&gt;switch(config-if)#exit&lt;br /&gt;switch(config)#interface fastethernet 0/4&lt;br /&gt;switch(config-if)#switchport mode access&lt;br /&gt;switch(config-if)#switchport access vlan  3&lt;br /&gt;switch(config-if)#exit&lt;br /&gt;switch(config)#exit&lt;br /&gt;switch#sh vlan&lt;br /&gt;&lt;br /&gt;VLAN Name                             Status    Ports&lt;br /&gt;---- -------------------------------- --------- -------------------------------&lt;br /&gt;1    default                          active    Fa0/5, Fa0/6, Fa0/7, Fa0/8&lt;br /&gt;                                               Fa0/9, Fa0/10, Fa0/11, Fa0/12&lt;br /&gt;2    VLAN2                            active    Fa0/1, Fa0/2&lt;br /&gt;3    vlan2                            active    Fa0/3, Fa0/4&lt;br /&gt;1002 fddi-default                     active&lt;br /&gt;1003 token-ring-default               active&lt;br /&gt;1004 fddinet-default                  active&lt;br /&gt;1005 trnet-default                    active&lt;br /&gt;&lt;br /&gt;VLAN Type  SAID       MTU   Parent RingNo BridgeNo Stp  BrdgMode Trans1 Trans2&lt;br /&gt;---- ----- ---------- ----- ------ ------ -------- ---- -------- ------ ------&lt;br /&gt;1    enet  100001     1500  -      -      -        -    -        0      0&lt;br /&gt;2    enet  100002     1500  -      -      -        -    -        0      0&lt;br /&gt;3    enet  100003     1500  -      -      -        -    -        0      0&lt;br /&gt;1002 fddi  101002     1500  -      -      -        -    -        0      0&lt;br /&gt;1003 tr    101003     1500  -      -      -        -    -        0      0&lt;br /&gt;1004 fdnet 101004     1500  -      -      -        ieee -        0      0&lt;br /&gt;1005 trnet 101005     1500  -      -      -        ibm  -        0      0&lt;br /&gt;&lt;br /&gt;--More--&lt;br /&gt;&lt;br /&gt;เสร็จแล้วก็ config ที่ switch ตัวที่ 2 ทำเหมือนกันกับตัวที่ 1&lt;br /&gt;&lt;br /&gt;ต่อไปจะ config vpt&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;switch(config)#vtp mode server&lt;br /&gt;Device mode already VTP SERVER.&lt;br /&gt;switch(config)#vtp domain server1&lt;br /&gt;Changing VTP domain name from NULL to server1&lt;br /&gt;switch(config)#exit&lt;br /&gt;switch#sh vtp status&lt;br /&gt;VTP Version                     : 2&lt;br /&gt;Configuration Revision          : 4&lt;br /&gt;Maximum VLANs supported locally : 64&lt;br /&gt;Number of existing VLANs        : 8&lt;br /&gt;VTP Operating Mode              : Server&lt;br /&gt;VTP Domain Name                 : server1&lt;br /&gt;VTP Pruning Mode                : Disabled&lt;br /&gt;VTP V2 Mode                     : Disabled&lt;br /&gt;VTP Traps Generation            : Disabled&lt;br /&gt;MD5 digest                      : 0x70 0x01 0xF2 0x72 0x97 0xA1 0x35 0xEB&lt;br /&gt;Configuration last modified by: 0.0.0.0 at 11-29-93 20:39:24&lt;br /&gt;Local updater ID is 0.0.0.0 on interface Vl1 (lowest numbered VLAN interface&lt;br /&gt;found)&lt;br /&gt;switch#&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-2199060251805172768?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/2199060251805172768/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=2199060251805172768' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2199060251805172768'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2199060251805172768'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/11/config-switch-vtp-mode.html' title='Config switch vtp mode'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://3.bp.blogspot.com/_kES3xlANtrU/SSwonoqWg2I/AAAAAAAAAPg/LZJsKCBIWOs/s72-c/lab2.jpg' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-3170736065240821406</id><published>2008-11-14T21:36:00.001-08:00</published><updated>2008-11-14T21:36:51.881-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='PHP'/><title type='text'>Remove element array in php</title><content type='html'>&lt;pre&gt;&lt;br /&gt;&lt;br /&gt;&lt;?php&lt;br /&gt;&lt;br /&gt;////////////////////////////////// Lists(Numerical Arrays) /////////////////////////////////&lt;br /&gt;&lt;br /&gt;/**&lt;br /&gt;&lt;br /&gt; * A small function to remove an element from a list(numerical array)&lt;br /&gt;&lt;br /&gt; * Arguments:    $arr - The array that should be edited&lt;br /&gt;&lt;br /&gt; *                $value - The value that should be deleted.&lt;br /&gt;&lt;br /&gt; * Returns    : The edited array&lt;br /&gt;&lt;br /&gt; */&lt;br /&gt;&lt;br /&gt;function array_remove($arr,$value) {&lt;br /&gt;&lt;br /&gt;   return array_values(array_diff($arr,array($value)));&lt;br /&gt;&lt;br /&gt;}&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;////////////////////////////////// Associative Arrays //////////////////////////////////////&lt;br /&gt;&lt;br /&gt;/**&lt;br /&gt;&lt;br /&gt; * This function will remove all the specified keys from an array and return the final array.&lt;br /&gt;&lt;br /&gt; * Arguments :    The first argument is the array that should be edited&lt;br /&gt;&lt;br /&gt; *                The arguments after the first argument is a list of keys that must be removed.&lt;br /&gt;&lt;br /&gt; * Example : array_remove_key($arr,"one","two","three");&lt;br /&gt;&lt;br /&gt; * Return : The function will return an array after deleting the said keys&lt;br /&gt;&lt;br /&gt; */&lt;br /&gt;&lt;br /&gt;function array_remove_key() {&lt;br /&gt;&lt;br /&gt;    $args = func_get_args();&lt;br /&gt;&lt;br /&gt;    $arr = $args[0];&lt;br /&gt;&lt;br /&gt;    $keys = array_slice($args,1);&lt;br /&gt;&lt;br /&gt;    &lt;br /&gt;&lt;br /&gt;    foreach($arr as $k=&gt;$v) {&lt;br /&gt;&lt;br /&gt;        if(in_array($k, $keys))&lt;br /&gt;&lt;br /&gt;            unset($arr[$k]);&lt;br /&gt;&lt;br /&gt;    }&lt;br /&gt;&lt;br /&gt;    return $arr;&lt;br /&gt;&lt;br /&gt;}&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;/**&lt;br /&gt;&lt;br /&gt; * This function will remove all the specified values from an array and return the final array.&lt;br /&gt;&lt;br /&gt; * Arguments :    The first argument is the array that should be edited&lt;br /&gt;&lt;br /&gt; *                The arguments after the first argument is a list of values that must be removed.&lt;br /&gt;&lt;br /&gt; * Example : array_remove_value($arr,"one","two","three");&lt;br /&gt;&lt;br /&gt; * Return : The function will return an array after deleting the said values&lt;br /&gt;&lt;br /&gt; */&lt;br /&gt;&lt;br /&gt;function array_remove_value() {&lt;br /&gt;&lt;br /&gt;    $args = func_get_args();&lt;br /&gt;&lt;br /&gt;    $arr = $args[0];&lt;br /&gt;&lt;br /&gt;    $values = array_slice($args,1);&lt;br /&gt;&lt;br /&gt;    &lt;br /&gt;&lt;br /&gt;    foreach($arr as $k=&gt;$v) {&lt;br /&gt;&lt;br /&gt;        if(in_array($v, $values))&lt;br /&gt;&lt;br /&gt;            unset($arr[$k]);&lt;br /&gt;&lt;br /&gt;    }&lt;br /&gt;&lt;br /&gt;    return $arr;&lt;br /&gt;&lt;br /&gt;}&lt;br /&gt;&lt;br /&gt;&lt;/pre&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-3170736065240821406?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/3170736065240821406/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=3170736065240821406' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3170736065240821406'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/3170736065240821406'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/11/remove-element-array-in-php.html' title='Remove element array in php'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-4488105678813307384</id><published>2008-10-26T19:14:00.000-07:00</published><updated>2008-10-26T19:15:20.829-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='sql'/><category scheme='http://www.blogger.com/atom/ns#' term='mysql'/><title type='text'>Finding Duplicates with sql</title><content type='html'>&lt;pre&gt;SELECT email,&lt;br /&gt;COUNT(email) AS NumOccurrences&lt;br /&gt;FROM users&lt;br /&gt;GROUP BY email&lt;br /&gt;HAVING ( COUNT(email) &gt; 1 )&lt;br /&gt;&lt;/pre&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-4488105678813307384?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/4488105678813307384/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=4488105678813307384' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/4488105678813307384'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/4488105678813307384'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/10/finding-duplicates-with-sql.html' title='Finding Duplicates with sql'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-8832247087511785047</id><published>2008-10-21T23:17:00.001-07:00</published><updated>2008-10-21T23:17:29.638-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='javascript'/><category scheme='http://www.blogger.com/atom/ns#' term='PHP'/><title type='text'>display ip on page</title><content type='html'>&lt;pre&gt;&lt;?&lt;span style="background-color: rgb(239, 239, 239);"&gt;&lt;br /&gt;&lt;/span&gt;//"ip.php" example- display user IP address on any page&lt;span style="background-color: rgb(239, 239, 239);"&gt;&lt;br /&gt;&lt;/span&gt;&lt;span style="color:#ff0000;"&gt;Header("content-type: application/x-javascript");&lt;/span&gt;&lt;br /&gt;$serverIP=$_SERVER['REMOTE_ADDR']&lt;span style="background-color: rgb(239, 239, 239);"&gt;;&lt;br /&gt;&lt;/span&gt;echo "document.write(\"Your IP address is: &lt;b&gt;" . $serverIP . "&lt;/b&gt;\")";&lt;span style="background-color: rgb(239, 239, 239);"&gt;&lt;br /&gt;&lt;/span&gt;?&gt;&lt;/pre&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-8832247087511785047?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/8832247087511785047/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=8832247087511785047' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/8832247087511785047'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/8832247087511785047'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/10/display-ip-on-page.html' title='display ip on page'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-7540214710425164946</id><published>2008-10-15T10:28:00.000-07:00</published><updated>2008-10-15T10:28:34.583-07:00</updated><title type='text'>Change joomla template</title><content type='html'>&lt;div style="MARGIN: 0px auto 10px; TEXT-ALIGN: center"&gt;Change joomla template&lt;br /&gt;&lt;br /&gt;goto site&gt;&gt;template manager &gt;&gt; site template&lt;br /&gt;&lt;a href="http://1.bp.blogspot.com/_kES3xlANtrU/SPYoQLuoy4I/AAAAAAAAAPQ/Vp6qeIQjlfk/s1600-h/changetemplate2.jpg"&gt;&lt;img border="0" alt="" src="http://1.bp.blogspot.com/_kES3xlANtrU/SPYoQLuoy4I/AAAAAAAAAPQ/Vp6qeIQjlfk/s320/changetemplate2.jpg" /&gt;&lt;/a&gt;&lt;br /&gt;&lt;/div&gt;&lt;br /&gt;&lt;div style="MARGIN: 0px auto 10px; TEXT-ALIGN: center"&gt;&lt;a href="http://1.bp.blogspot.com/_kES3xlANtrU/SPYoQVfH75I/AAAAAAAAAPY/U9D235CdAHY/s1600-h/changetemplate.jpg"&gt;&lt;img border="0" alt="" src="http://1.bp.blogspot.com/_kES3xlANtrU/SPYoQVfH75I/AAAAAAAAAPY/U9D235CdAHY/s320/changetemplate.jpg" /&gt;&lt;/a&gt; &lt;/div&gt;&lt;div style='clear:both; text-align:CENTER'&gt;&lt;a href='http://picasa.google.com/blogger/' target='ext'&gt;&lt;img src='http://photos1.blogger.com/pbp.gif' alt='Posted by Picasa' style='border: 0px none ; padding: 0px; background: transparent none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;' align='middle' border='0' /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-7540214710425164946?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/7540214710425164946/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=7540214710425164946' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/7540214710425164946'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/7540214710425164946'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/10/change-joomla-template.html' title='Change joomla template'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://1.bp.blogspot.com/_kES3xlANtrU/SPYoQLuoy4I/AAAAAAAAAPQ/Vp6qeIQjlfk/s72-c/changetemplate2.jpg' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-2643409276706355622</id><published>2008-10-15T10:25:00.000-07:00</published><updated>2008-10-15T10:25:57.315-07:00</updated><title type='text'></title><content type='html'>&lt;a href="http://1.bp.blogspot.com/_kES3xlANtrU/SPYnozkZGwI/AAAAAAAAAPI/OjadIh1Jguk/s1600-h/changetemplate2.jpg"&gt;&lt;img style="FLOAT: left; MARGIN: 0px 10px 10px 0px; CLEAR: both" border="0" alt="" src="http://1.bp.blogspot.com/_kES3xlANtrU/SPYnozkZGwI/AAAAAAAAAPI/OjadIh1Jguk/s320/changetemplate2.jpg" /&gt;&lt;/a&gt;&lt;div style='clear:both; text-align:LEFT'&gt;&lt;a href='http://picasa.google.com/blogger/' target='ext'&gt;&lt;img src='http://photos1.blogger.com/pbp.gif' alt='Posted by Picasa' style='border: 0px none ; padding: 0px; background: transparent none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;' align='middle' border='0' /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-2643409276706355622?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/2643409276706355622/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=2643409276706355622' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2643409276706355622'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/2643409276706355622'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/10/blog-post.html' title=''/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://1.bp.blogspot.com/_kES3xlANtrU/SPYnozkZGwI/AAAAAAAAAPI/OjadIh1Jguk/s72-c/changetemplate2.jpg' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-4477815214050206390</id><published>2008-10-14T20:54:00.000-07:00</published><updated>2008-10-14T20:56:57.583-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='xml'/><title type='text'>XML super ster contest</title><content type='html'>More detail &lt;a href="http://www.asean.xmlsuperstar.com/web/guest/home"&gt;http://www.asean.xmlsuperstar.com/web/guest/home&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;่น่าสนใจครับ เปิดรับสมัครถึงวันที่ &lt;b&gt;28 February 2009 &lt;/b&gt;ก็จะมีหลายรายการที่จัดแข่งขันครับเข้าไปดูรายละเอียดได้&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-4477815214050206390?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/4477815214050206390/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=4477815214050206390' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/4477815214050206390'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/4477815214050206390'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/10/xml-super-ster-contest.html' title='XML super ster contest'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-5953587168828817640</id><published>2008-10-14T09:34:00.000-07:00</published><updated>2008-10-14T09:36:07.753-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='บริษัท'/><title type='text'>asiasoft.co.th</title><content type='html'>พอดีวันนี้ได้เข้าไปเจอเว็บหนึ่งชื่อว่า asiasoft.co.th ไปหน้าแรกเห็น product ของเขาเลยครับว่าเขาทำอะไรบ้าง เห็นเพื่อนมันเล่นเกมส์ ragnarok กันแต่ไม่รู้ว่าบริษัทไหนทำ พึ่งรู้ว่าเป็น asiasoft.co.th ก็วันนี้ละครับ&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-5953587168828817640?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/5953587168828817640/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=5953587168828817640' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/5953587168828817640'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/5953587168828817640'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/10/asiasoftcoth.html' title='asiasoft.co.th'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-2669059752766299103.post-8810892761669613910</id><published>2008-10-14T06:17:00.000-07:00</published><updated>2008-10-14T06:20:12.206-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='engine'/><category scheme='http://www.blogger.com/atom/ns#' term='search'/><category scheme='http://www.blogger.com/atom/ns#' term='search engine'/><title type='text'>Gazopa picture search engine</title><content type='html'>วันนี้มารู้จัก web gazopa.com กันครับ&lt;br /&gt;&lt;br /&gt;เป็นเว็บ search engine แต่เป็นเว็บ search เกี่ยวกับรูปภาพนะครับ&lt;br /&gt;ลองเล่นดูแล้วจะรู้ว่ามันทำได้ยังไงวะ&lt;br /&gt;&lt;br /&gt;&lt;a href="http://www.gazopa.com/demo_video"&gt;http://www.gazopa.com/demo_video&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/2669059752766299103-8810892761669613910?l=awatblog.blogspot.com'/&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://awatblog.blogspot.com/feeds/8810892761669613910/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=2669059752766299103&amp;postID=8810892761669613910' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/8810892761669613910'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/2669059752766299103/posts/default/8810892761669613910'/><link rel='alternate' type='text/html' href='http://awatblog.blogspot.com/2008/10/gazopa-picture-search-engine.html' title='Gazopa picture search engine'/><author><name>wirat</name><uri>http://www.blogger.com/profile/15118904673598775862</uri><email>noreply@blogger.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='09281068809630162250'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry></feed>