ให้เรตสมาชิก: 2 / 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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
การใช้ Firebase ทำในโปรเจค Android
โดย rangsan ส 26 พฤษภาคม 2018 6:26 pm บอร์ด Mobile Application Developing- Android, iOS
0
12
ส 26 พฤษภาคม 2018 6:26 pm โดย rangsan
Q - ทำเมนูตอนย่อหน้าจอแล้วกำหนดให้เมนูยังแสดงอยู่บ้างบางส่วน
โดย Parichat ส 26 พฤษภาคม 2018 3:35 pm บอร์ด HTML CSS
2
16
ส 26 พฤษภาคม 2018 4:54 pm โดย Parichat
Q - ่Accounting ไม่สามารถกด Validate ที่ Cash Transfer ได้
โดย Rujikon ส 26 พฤษภาคม 2018 3:26 pm บอร์ด บวรเวชสมุนไพรไทย จำกัด - Tester
2
7
ส 26 พฤษภาคม 2018 5:42 pm โดย Rujikon
Q - ทำการ Sale แล้วขึ้น OpenERP Server Error
โดย Rujikon ส 26 พฤษภาคม 2018 2:16 pm บอร์ด บวรเวชสมุนไพรไทย จำกัด - Tester
2
10
ส 26 พฤษภาคม 2018 2:37 pm โดย mindphp
งานประจำวันที่ 26 พฤษภาคม 2561
โดย Rujikon ส 26 พฤษภาคม 2018 12:25 pm บอร์ด M060 - นายรุจิกร พงษ์พิละ
1
3
อ 27 พฤษภาคม 2018 1:58 pm โดย Rujikon
Q - กด Create ในเมนู Employees แล้ว Error
โดย Rujikon ส 26 พฤษภาคม 2018 11:56 am บอร์ด บวรเวชสมุนไพรไทย จำกัด - Tester
0
15
ส 26 พฤษภาคม 2018 11:56 am โดย Rujikon
Q - Overrides Component JoomShopping มาได้แค่โฟลเดอร์แต่ไม่มีไฟล์
โดย Parichat ส 26 พฤษภาคม 2018 11:01 am บอร์ด Joomla Development
0
9
ส 26 พฤษภาคม 2018 11:01 am โดย Parichat
งานประจำวันที่ 26 พฤษภาคม 2561
โดย Parichat ส 26 พฤษภาคม 2018 9:40 am บอร์ด M061 - ปาริชาติ รัตโณภาส
1
2
ส 26 พฤษภาคม 2018 7:13 pm โดย Parichat
งานประจำวันที่ 26 พฤษภาคม 2561
โดย rangsan ส 26 พฤษภาคม 2018 9:32 am บอร์ด M058 - รังสรรค์ มุ่งกลาง
1
5
ส 26 พฤษภาคม 2018 6:30 pm โดย rangsan
R - ปรับให้ Product ใน JoomShopping อัพรูปภาพตามสีได้
โดย tsukasaz ศ 25 พฤษภาคม 2018 5:49 pm บอร์ด Doy-shop ( 15 พ.ค. - 29 พ.ค. 61)
0
4
ศ 25 พฤษภาคม 2018 5:49 pm โดย tsukasaz
B - ไม่สามารถ Import Serial Outgoing ได้ครับ [2018-05][004]
โดย AePongsak ศ 25 พฤษภาคม 2018 4:58 pm บอร์ด อาร์ซีพี โกลบอล จำกัด - Tester
1
11
ศ 25 พฤษภาคม 2018 6:33 pm โดย nuattawoot
เข้าใช้ไม่ได้ค่ะ [2018-05][003]
โดย Rujikon ศ 25 พฤษภาคม 2018 4:36 pm บอร์ด บวรเวชสมุนไพรไทย จำกัด - Tester
2
15
ส 26 พฤษภาคม 2018 3:12 pm โดย Rujikon
Q - ทำรูปภาพให้สามารถเปลี่ยนสีได้ตามต้องการ
โดย Parichat ศ 25 พฤษภาคม 2018 4:04 pm บอร์ด Joomla Dev
12
33
ศ 25 พฤษภาคม 2018 6:20 pm โดย Parichat
Q - ย่อสินค้าให้เท่ากับพื้นหลัง
โดย Parichat ศ 25 พฤษภาคม 2018 3:40 pm บอร์ด Joomla Dev
16
36
ศ 25 พฤษภาคม 2018 6:15 pm โดย Parichat
Q - ใน Joomshopping ในหน้าเว็บเอา Order by กับ Display ออก
โดย Parichat ศ 25 พฤษภาคม 2018 3:04 pm บอร์ด Joomla Development
2
16
ศ 25 พฤษภาคม 2018 3:21 pm โดย Parichat
B - การใช้งาน Logged calls
โดย watcharin ศ 25 พฤษภาคม 2018 2:37 pm บอร์ด M.D.Soft Co.,Ltd. - Tester
0
4
ศ 25 พฤษภาคม 2018 2:37 pm โดย watcharin
Q - จัดพื้นหลังให้เท่ากับเมนูด้านบน
โดย Parichat ศ 25 พฤษภาคม 2018 2:20 pm บอร์ด HTML CSS
1
18
ศ 25 พฤษภาคม 2018 2:50 pm โดย Parichat
B - ภาษีต้องเพิ่ม จากราคา
โดย thatsawan ศ 25 พฤษภาคม 2018 1:26 pm บอร์ด M.D.Soft Co.,Ltd. - Tester
1
3
ศ 25 พฤษภาคม 2018 1:27 pm โดย thatsawan
Work's on Hand ปาริชาติ รัตโณภาส MT21
โดย Parichat จ 08 ม.ค. 2018 12:11 pm บอร์ด M061 - ปาริชาติ รัตโณภาส
19
1
ศ 25 พฤษภาคม 2018 4:26 pm โดย Parichat
งานประจำวันที่ 25 พฤษภาคม 2561
โดย Rujikon ศ 25 พฤษภาคม 2018 11:46 am บอร์ด M060 - นายรุจิกร พงษ์พิละ
2
12
ศ 25 พฤษภาคม 2018 8:06 pm โดย nuattawoot