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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
input type="date" ไม่เเสดงเป็นปฎิทินวันที่ให้ใน safari แก้ไขยังไงคะ
โดย thatsawan พฤ 02 ก.ค. 2020 2:31 pm บอร์ด HTML CSS
0
17
พฤ 02 ก.ค. 2020 2:31 pm โดย thatsawan
การสร้าง bot messenger ของ facebook โดยใช้ pymessenger
โดย jirawoot พฤ 02 ก.ค. 2020 1:44 pm บอร์ด Python Knowledge
0
15
พฤ 02 ก.ค. 2020 1:44 pm โดย jirawoot
Q - ทดลองทำเอกสารยื่นแบบผ่านเน็ตแล้ว ไฟล์ txt ใช้ไม่ได้
โดย natthanit.r2538 พ 01 ก.ค. 2020 4:59 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
3
34
พ 01 ก.ค. 2020 5:41 pm โดย natthanit.r2538
สรุปการยื่นแบบภาษีออนไลน์
โดย natthanit.r2538 อ 30 มิ.ย. 2020 5:32 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
1
34
อ 30 มิ.ย. 2020 7:18 pm โดย natthanit.r2538
หลักการคิดค่าคอมมิชชั่น และวิธีการคิด รายได้จาก Commission
โดย natthanit.r2538 อ 30 มิ.ย. 2020 11:31 am บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
34
อ 30 มิ.ย. 2020 11:31 am โดย natthanit.r2538
MJUpgrade อัพเกรดไม่สำเร็จ Error: zip file not found
โดย chaiyaphat ศ 26 มิ.ย. 2020 11:01 am บอร์ด Joomla Development
3
482
ศ 26 มิ.ย. 2020 1:24 pm โดย mindphp
ตั้งค่าใช้ Email ใน phpbb เเล้ว ไม่ทำงาน
โดย thatsawan พฤ 25 มิ.ย. 2020 5:37 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
5
72
ส 27 มิ.ย. 2020 4:43 pm โดย thatsawan
เจอปัญหาตอนทำรายการ Omise เป็นบางครั้ง Error Uncaught OmiseInvalidChargeException
โดย thatsawan พฤ 25 มิ.ย. 2020 3:56 pm บอร์ด Programming - PHP
2
54
จ 29 มิ.ย. 2020 5:29 pm โดย thatsawan
ต้องการจะสร้างไฟล์ HTML เเต่นำค่า php ไป HTML โดย Twig เขียนใน phpbb จะทำยังไงคะ
โดย thatsawan พ 24 มิ.ย. 2020 5:45 pm บอร์ด Programming - PHP
3
60
พฤ 25 มิ.ย. 2020 3:49 pm โดย Sirayu
ถ้าเราต้องการแสดงค่าตอน onchange ใน option ที่มี value มากกว่า 1
โดย thatsawan อ 23 มิ.ย. 2020 12:51 pm บอร์ด JavaScript & Jquery Ajax
2
104
อ 23 มิ.ย. 2020 3:01 pm โดย thatsawan
4 จุดเช็คอิน เกาะล้าน ยอดฮิต
โดย A2d จ 22 มิ.ย. 2020 10:44 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
2
61
ส 27 มิ.ย. 2020 12:01 am โดย A2d
ต้องการจะเปลี่ยนคำปุ่ม omise จาก Pay with Omise เป็นคำที่เรากำหนดขึ้นเอง
โดย thatsawan จ 22 มิ.ย. 2020 5:18 pm บอร์ด PHP Knowledge
2
87
จ 22 มิ.ย. 2020 5:39 pm โดย thatsawan
สาเหตุที่เด็กทารกแพ้นมวัว คุณแม่จะรับมือปัญหานี้อย่างไรดี
โดย medalezga จ 22 มิ.ย. 2020 1:58 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
53
จ 22 มิ.ย. 2020 1:58 pm โดย medalezga
ไม่เข้าใจคำสั่ง preg_replace
โดย profess79 ส 20 มิ.ย. 2020 11:56 am บอร์ด Programming - PHP
1
87
ส 20 มิ.ย. 2020 6:19 pm โดย profess79
วิธีการทำทศนิยม 3 ตำแหน่ง ด้วย python
โดย bolue ศ 19 มิ.ย. 2020 4:49 pm บอร์ด Python Knowledge
0
69
ศ 19 มิ.ย. 2020 4:49 pm โดย bolue
วิธีการ เพิ่มข้อมูล ลงฐานข้อมูล พร้อม รีเทิร์น id กลับมา ด้วยคำสั่ง sql
โดย bolue ศ 19 มิ.ย. 2020 3:25 pm บอร์ด SQL Knowledge
0
537
ศ 19 มิ.ย. 2020 3:25 pm โดย bolue
เจอปัญหา ส่งเมลผิดพลาด : Language string failed to load: from_failed บน phpmailer
โดย mindphp ศ 19 มิ.ย. 2020 3:26 am บอร์ด Programming - PHP
2
1421
ศ 19 มิ.ย. 2020 5:47 pm โดย mindphp
กฎหมายที่ใช้ควบคุมโรค โควิด-19 ฝ่าฝืนได้รับโทษอย่างไรบ้าง?
โดย Decha Thaweeumanjvaroj พฤ 18 มิ.ย. 2020 10:17 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
93
พฤ 18 มิ.ย. 2020 10:17 am โดย Decha Thaweeumanjvaroj
ไม่สามารถ start openerp-server ของ openerp 7 ได้
โดย bolue พฤ 18 มิ.ย. 2020 10:09 am บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
10
151
ศ 19 มิ.ย. 2020 12:49 pm โดย bolue
ติดตั้ง ERP 7 ไม่ได้ค่ะ
โดย bolue พ 17 มิ.ย. 2020 4:01 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
12
137
ส 27 มิ.ย. 2020 12:47 am โดย mindphp