ให้เรตสมาชิก: 3 / 5

ดาวใช้งานดาวใช้งานดาวใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

Create Table AS (ครีเอทเทเบิลแอส) หรือ การสร้างตารางจากตารางที่มีอยู่ 

!! การสร้างตารางนี้สร้างขึ้นมาสำหรับเป็นตัวอย่างในการเขียน SQL บน PostgreSQL เท่านั้น

    จากบทความเรื่องการ  Create Table (ครีเอท เทเบิล) ซึ่งเป็นการเพิ่มตารางอย่างง่าย และ การ การ Create Table (ครีเอทเทเบิล) แบบ INHERITS (อินเฮริท) เป็นการเพิ่มตารางโดยทำการสืบทอดคุณสมบัติของตารางมา 

  ในบทความนี้ จะกล่าวถึงการสร้างตารางด้วยวิธีการ คัดลอกคอลัมน์จากตารางที่มีอยู่แล้ว 

ซึ่งจะเป็นการเลือกคัดลอกมาเพียงบางคอลัมน์ ไม่ใช่การยกมาทั้งหมดเหมือนการ inherits

ตัวอย่างการสร้างตาราง

วิธีการที่ 1 : การคัดลอกคอลัมน์มาทั้งหมด

CREATE TABLE table_name

   AS (SELECT * FROM table_name_old);

อธิบายคำสั่ง

table_name (เทเบิล_เนม) :  ชื่อตารางที่ต้องการสร้าง

*               :  เลือกคอลัมน์มาทั้งหมด

table_name_old (เทเบิล_เนม_โอน) :  ชื่อตารางที่ต้องการคัดลอกคอลัมน์มา

โค้ด :

CREATE TABLE z_testcreatetable_partner

   AS (SELECT * FROM res_partner);

ตัวอย่าง :

การคัดลอกคอลลัมน์จากตารางมาทั้งหมด
การคัดลอกคอลลัมน์จากตารางมาทั้งหมด

ผลที่ได้ :

CREATE TABLE z_testcreatetable_partner

(

  id integer,

  name character varying(128),

  lang character varying(64),

  company_id integer,

  create_uid integer,

  create_date timestamp without time zone,

  write_date timestamp without time zone,

  write_uid integer,

  comment text,

  ean13 character varying(13),

  color integer,

  image bytea,

  use_parent_address boolean,

  active boolean,

  street character varying(128),

  supplier boolean,

  city character varying(128),

  user_id integer,

  zip character varying(24),

  title integer,

  function character varying(128),

  country_id integer,

  parent_id integer,

  employee boolean,

  type character varying,

  email character varying(240),

  vat character varying(32),

  website character varying(64),

  fax character varying(64),

  street2 character varying(128),

  phone character varying(64),

  credit_limit double precision,

  date date,

  tz character varying(64),

  customer boolean,

  image_medium bytea,

  mobile character varying(64),

  ref character varying(64),

  image_small bytea,

  birthdate character varying(64),

  is_company boolean,

  state_id integer

)

WITH (

  OIDS=FALSE

);

ALTER TABLE z_testcreatetable_partner

  OWNER TO openpg;

คำอธิบาย : 

จากภาพตัวอย่างที่ 1 เป็นการสร้างตารางที่มีชื่อว่า "z_testcreatetable_partner" (แซด_เทสครีเอทเทเบิล_พาร์ทเนอร์)

โดยตาราง z_testcreatetable_partner จะทำการคัดลอกคอลัมน์ภายในตาราง "res_partner" (เรส_พาร์ทเนอร์) มาทั้งหมด 

จากคำสั่ง AS (SELECT * FROM table_name_old) (แอด(ซีเล็ท*ฟอร์ม เทเบิล_เนม_โอน)

เครื่องหมาย * คือคำสั่งให้เลือกทั้งหมด

วิธีการที่ 2 : การคัดลอกมาเพียงบางคอลัมน์

CREATE TABLE table_name

   AS (SELECT column_1, column2, ... column_n

   FROM table_name_old); 

อธิบายคำสั่ง

table_name (เทเบิล_เนม) :  ชื่อตารางที่ต้องการสร้าง

column_1....n (คอลลัมน์_1...n)  :  คอลัมน์ที่ต้องการคัดลอกมา

table_name_old (เทเบิล_เนม_โอน) :  ชื่อตารางที่ต้องการคัดลอกคอลัมน์มา

โค้ด :

CREATE TABLE z_testcreatetable_cpartner

  AS (SELECT   

  id,

  name,

  lang,

  title,

  email,

  mobile,

  birthdate,

  state_id  FROM res_partner) ;

ตัวอย่าง :

การคัดลอกคอลลัมน์จากตารางมาเพียงบางคอลลัมน์
การคัดลอกคอลลัมน์จากตารางมาเพียงบางคอลลัมน์

ผลที่ได้ :

CREATE TABLE z_testcreatetable_cpartner

(

  id integer,

  name character varying(128),

  lang character varying(64),

  title integer,

  email character varying(240),

  mobile character varying(64),

  birthdate character varying(64),

  state_id integer

)

WITH (

  OIDS=FALSE

);

ALTER TABLE z_testcreatetable_cpartner

  OWNER TO openpg;

คำอธิบาย :

ในภาพตัวอย่างที่ 2 เป็นการสร้างตาราง "z_testcreatetable_cpartner" (แซด_เทสครีเอทเทเบิล_ซีพาร์ทเนอร์) วิธีการคล้ายกับการสร้างตาราง "z_testcreatetable_partner" 

เพียงแต่ว่า จะทำการเลือกคัดลอกมาเพียงบางคอลัมน์ ในตาราง "z_testcreatetable_cpartner" นี้

เลือกทำการคัดลอกมาเพียงคอลัมร์ที่ชื่อว่า id, name, lang, title, email, mobile, birthdate และ state_id เท่านั้นไม่ได้คัดลอกมาทั้งหมด

ศึกษาเพิ่มเติมได้ที่ : รวมคำสั่ง SQL ต่างๆ

www.postgresqltutorial.com Eng.ver

www.postgresql.org Eng.ver

โดย : http://www.mindphp.com

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
MOD_MTB_NEWS_RECENT
หานักศึกษาทำงาน part time ช่วยงานติดตั้งระบบปฏิบัติการบน VMWare
โดย บุคคลทั่วไป อ 22 ต.ค. 2017 1:03 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
8
อ 22 ต.ค. 2017 1:03 am โดย บุคคลทั่วไป
สอบถามเรื่องการ insert ข้อมูลในรูปแบบ multiple ครับ
โดย Nueng Chiramet ส 21 ต.ค. 2017 8:00 pm บอร์ด Programming - PHP
1
8
ส 21 ต.ค. 2017 8:00 pm โดย mindphp
สอบถามเรื่องการ insert ข้อมูลในรูปแบบ multiple ครับ
โดย Nueng Chiramet ส 21 ต.ค. 2017 7:47 pm บอร์ด Programming - PHP
0
5
ส 21 ต.ค. 2017 7:47 pm โดย Nueng Chiramet
เรื่องจริงที่ Developer ทุกคนเคยเจอ
โดย Before Dong ศ 20 ต.ค. 2017 9:32 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
34
ศ 20 ต.ค. 2017 9:32 am โดย Before Dong
ภาพความฝัน กับความจริง ตอนรันโปรแกรม รันกราฟโชว์ผลงาน
โดย Before Dong พฤ 19 ต.ค. 2017 10:30 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
3
124
ศ 20 ต.ค. 2017 9:15 am โดย Before Dong
อยากหัดเขียนโปรแกรมเซฟรูปจากห้องแชทในไลน
โดย pwbank พฤ 19 ต.ค. 2017 11:59 pm บอร์ด Programming - C/C++ & java & Python
0
18
พฤ 19 ต.ค. 2017 11:59 pm โดย pwbank
เขียนโค้ดยังไงให้จับคู่ตัวเลขทุกตัว โดยใช้ javascript เท่านั้น
โดย mybbb พฤ 19 ต.ค. 2017 9:59 pm บอร์ด JavaScript & Jquery Ajax
0
11
พฤ 19 ต.ค. 2017 9:59 pm โดย mybbb
ตัวอย่างการใช้คำสั่ง time.sleep() ใน Selenium
โดย paoonline พฤ 19 ต.ค. 2017 6:58 pm บอร์ด Python Knowledge
0
23
พฤ 19 ต.ค. 2017 6:58 pm โดย paoonline
ติดตั้ง จูมช็อบปิ้งไม่ได้ครับ Error
โดย chungchai พ 18 ต.ค. 2017 7:54 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS CRM
4
31
พ 18 ต.ค. 2017 7:54 pm โดย xampp
ตัวอย่าง การดึงข้อมูลเวลาวันที่จากฐานข้อมูลมาแปลงเป็นรูปแบบ Date Time(เดททาม) สากล
โดย paoonline พ 18 ต.ค. 2017 4:05 pm บอร์ด Python Knowledge
0
39
พ 18 ต.ค. 2017 4:05 pm โดย paoonline
ยกเลิก Class ชื่อ JDocumentRendererHead ในเวอร์ชั่น 3.8.0 ขึ้นไป ทำให้เกิด Error ที่หน้าเว็บไซต์
โดย tsukasaz พ 18 ต.ค. 2017 3:58 pm บอร์ด Joomla Development
0
20
พ 18 ต.ค. 2017 3:58 pm โดย tsukasaz
เส้นทางที่โรยด้วย กลีบกุหลาบ ของโปรแกรมเมอร์
โดย Before Dong พ 18 ต.ค. 2017 11:29 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
262
พ 18 ต.ค. 2017 11:29 am โดย Before Dong
คำสั่ง ดู พื้นที่ใน Folder Linux
โดย mindphp อ 17 ต.ค. 2017 9:42 pm บอร์ด Linux - Web Server
2
43
อ 17 ต.ค. 2017 9:42 pm โดย mindphp
สอบถามไม่สามารถใช้ Selenium IDE ใน Firefox ได้ครับ
โดย paoonline อ 17 ต.ค. 2017 4:39 pm บอร์ด Programming - C/C++ & java & Python
0
36
อ 17 ต.ค. 2017 4:39 pm โดย paoonline
สอบถามถ้าต้องการเช็คค่าที่เป็นจุดทศนิยมเเล้วต้องการปัดลงจะทำยังไงได้บ้างค่ะ
โดย thatsawan อ 17 ต.ค. 2017 1:42 pm บอร์ด Programming - C/C++ & java & Python
2
68
อ 17 ต.ค. 2017 1:42 pm โดย jataz2
Project Manager VS Developer - เมื่อประชุมทีมพัฒนา
โดย Before Dong อ 17 ต.ค. 2017 10:41 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
82
อ 17 ต.ค. 2017 10:41 am โดย Before Dong
หนังสือส่งมอบงาน +คู่มือ+วีดีโอ+Cheklist - อะเมริซีด อินเตอร์เนชัน แนล จำกัด
โดย M029 จ 16 ต.ค. 2017 3:53 pm บอร์ด อะเมริซีด อินเตอร์เนชัน แนล จำกัด
0
2
จ 16 ต.ค. 2017 3:53 pm โดย M029
Project Manager VS Developer - เมื่อต้อง set demo เว็บไซต์
โดย Before Dong จ 16 ต.ค. 2017 11:15 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
1243
จ 16 ต.ค. 2017 11:15 am โดย Before Dong
แก้ปัญหา PGSQL FATAL: sorry, too many clients already.
โดย mindphp ส 14 ต.ค. 2017 1:35 am บอร์ด PostgreSQL
0
49
ส 14 ต.ค. 2017 1:35 am โดย mindphp
จะสร้าง FTP account ใน cpanel ยังไง พอมีวิธ๊แนะนำมั้ย
โดย บุคคลทั่วไป ศ 13 ต.ค. 2017 11:04 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS CRM
0
48
ศ 13 ต.ค. 2017 11:04 pm โดย บุคคลทั่วไป