Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
   
 

Registered : 102,592


HOME > Oracle สอนเขียน Stored Procedure, Table, View, Function, Trigger บน Oracle Database > ตอนที่ 8 : การสร้าง Declare Temp Table - TEMPORARY (Oracle : Stored Procedure)

ตอนที่ 8 : การสร้าง Declare Temp Table - TEMPORARY (Oracle : Stored Procedure)

 
 


Bookmark.   
Share
       
ตอนที่ 8 : การสร้าง Declare Temp Table - TEMPORARY (Oracle : Stored Procedure) ในการเขียน Stored Procedure บน Oracle Database เราสามารถให้ Stored Procedure เรียกใช้งาน Temp Table ได้เช่นเดียวกัน ซึ่งจะเป็นเสมือนการสร้าง Table ชั่วคราว จุดเด่นของ Temp Table ในการเขียน Store Procedure คือ โดยพื้นฐานแล้วการเขียน Query เพื่ออ่านข้อมูลจาก Table ก็คือการดึงค่า Result กลับมาใช้บน Application และในกรณีถ้า SQL Query ที่มีความซับซ้อนจนกว่าจะเขียน Query ในแบบปกติได้ เราก็จะใช้การ Select ค่า Result แต่ล่ะส่วน แล้วค่อนนำค่าที่ได้ไป Insert ลงใน Temp Table และเมื่อได้ค่า Result ทั้งหมดที่ต้องการแล้วก็จะใช้การ Select ข้อมูลแล้วคาอยส่งกลับไปยังตัว Call ซึ่งวินี้นี้ก็เป็นวิธีที่ถูกนิยมนำมาใช้งานกันอย่างมาก และการเขียนก็ค่อนข้างง่าย เพียงแค่สร้าง Temp Table พร้อมกับ Column และ Data Type จากนั้นสามารถทำการ Insert ข้อมูลลงใน Table หรือจะเลือก Insert จาก Table อื่น ๆ จนครบตามความต้องการ แล้วค่อยส่งค่าทั้งหมดกลัลบไป ส่วนข้อมูลต่าง ๆ ใน Temp Table ทั้งหมด เมื่อมีการ Commit แล้ว ข้อมูลที่ถูก Insert ลงไปจะหาย Delete ไปอัตโมนัติ

Table : CUSTOMER

Oracle Database Create Table

Declare TABLE Syntax
CREATE GLOBAL TEMPORARY TABLE temp_table (
  NO NUMBER(1), 
  NAME            VARCHAR2(50),
  COUNTRY_NAME    VARCHAR2(50)
)
ON COMMIT DELETE ROWS;

Declare Temp Table Oracle : Stored Procedure

ในการสร้าง Temp Table หรือ Temporary Table จะไม่สามารถสร้างได้ใน Stored Procedure จะต้องสร้างเหมือนกับการสร้าง Table ทั่ว ๆ ไป แล้วใน Stored Procedure ค่อยเรียกใช้งาน ส่วนคำสั่ง ON COMMIT DELETE ROWS; คือจะมีการ Delete ข้อมูลอัโตนมัติเมื่อ Commit หรือ ทำงานเสร็จสิ้น

Declare Temp Table Oracle : Stored Procedure

Example 1 : การสร้างเรียกใช้และ Insert ข้อมูลงใน Temp Table พร้อมกับส่งค่ากลับไป
CREATE OR REPLACE PROCEDURE GET_CUSTOMER
AS
BEGIN
     
  -- Insert Table
  INSERT INTO temp_table (NO,NAME,COUNTRY_NAME) VALUES ('1','Weerachai Nukitram','Thailand');
  INSERT INTO temp_table (NO,NAME,COUNTRY_NAME) VALUES ('2','Surachai Sirisart','United Stats');
  INSERT INTO temp_table (NO,NAME,COUNTRY_NAME) VALUES ('3','Adisorn Boonsong','United Kingdom');
  
  -- Loop Table
  FOR CusInfo IN (SELECT * FROM temp_table)
  LOOP
      DBMS_OUTPUT.PUT_LINE(CusInfo.NO || ' ' || CusInfo.NAME || ' ' || CusInfo.COUNTRY_NAME);
  END LOOP;
  
  COMMIT;
               
END;
ตัวอย่างนี้จะเป็นการการ Insert ข้อมูลลงใน Table และการ Loop ข้อมูลของ temp_table และแสดง OUTPUT ออกทาง DBMS_OUTPUT

Call
EXEC GET_CUSTOMER()

Result

Declare Temp Table Oracle : Stored Procedure


Example 2 : การ เรียกใช้ Temp Table และ Insert ข้อมูลงใน Table และการ Return ข้อมูลจาก Temp Table ไปยังตัว Call ผ่าน OUT และ SYS_REFCURSOR
CREATE OR REPLACE PROCEDURE GET_CUSTOMER(pCustomer OUT SYS_REFCURSOR)
AS
BEGIN
     
      -- Insert Temp Table
      INSERT INTO temp_table (NO,NAME,COUNTRY_NAME) VALUES ('1','Weerachai Nukitram','Thailand');
      INSERT INTO temp_table (NO,NAME,COUNTRY_NAME) VALUES ('2','Surachai Sirisart','United Stats');
      INSERT INTO temp_table (NO,NAME,COUNTRY_NAME) VALUES ('3','Adisorn Boonsong','United Kingdom');
      
       -- Return  SYS_REFCURSOR
      OPEN pCustomer FOR SELECT * FROM temp_table;

       -- Commit
      COMMIT;
            
END;
ตัวอย่างนี้จะเป็นการ Insert ข้อมูลลงใน Temp Table และการ Select ข้อมูลจาก Temp Table แล้ว Return ค่าไปยังตัว Call ผ่าน Parameters ของ OUT ชนิด SYS_REFCURSOR

Call
VAR  pCustomer REFCURSOR;
EXEC GET_CUSTOMER(:pCustomer)
PRINT pCustomer;

Result

Declare Temp Table Oracle : Stored Procedure

   
Share




ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท

ลองใช้ค้นหาข้อมูล


   
  By : ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ)
  Score Rating :  
  Create/Update Date : 2015-10-24 20:40:57 / 2015-11-05 21:42:22
  Download : No files
Sponsored Links
 
 Sponsored Links / Related
 
ตอนที่ 1 : ดาวน์โหลดและติดตั้ง Database Oracle 11g ฟรี จากเว็บไซต์ของ Oracle
Rating :
 
ตอนที่ 2 : การสร้าง Database และ Instance ใหม่บน Oracle Database
Rating :
 
ตอนที่ 3 : ติดตั้ง Oracle SQL Developer จัดการกับ Oracle Database การสร้าง User/Grant สิทธิ์
Rating :
 
ตอนที่ 4 : การสร้าง Table และ Insert เพิ่ม Data ลงใน Table ของ Oracle Database
Rating :
 
ตอนที่ 5 : รู้จัก Stored Procedure บน Oracle การรับส่ง Parameters (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 6 : การ Print Message และ DBMS_OUTPUT.PUT_LINE (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 7 : การสร้างตัวแปร Declare Variable บน Store Procedure (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 9 : การสร้าง Loop ข้อมูลบน Store Procedure (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 10 : การใช้ Cursor บน Stored Procedure (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 11 : การใช้ IF....ELSE...ELSEIF... สร้างเงื่อนไข (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 12 : การใช้ Try Catch Exception ดักจับข้อผิดลาด (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 13 : การใช้ Transaction บน Oracle Stored Procedure (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 14 : รู้จัก Oracle Package คืออะไร การใช้งาน Package (Oracle : Stored Procedure)
Rating :
 
ตอนที่ 15 : การสร้าง VIEW Table บน Oracle Database (Oracle : View Table)
Rating :
 
ตอนที่ 16 : การสร้าง Function บน Oracle Database (Oracle : Function)
Rating :
 
ตอนที่ 17 : การสร้าง Trigger Events บน Oracle Database (Oracle : Trigger)
Rating :
 
ตอนที่ 18 : การสร้าง Export/Import รายการ Table และอื่น ๆ บน Oracle Database
Rating :
 
ตอนที่ 19 : PHP ฟังก์ชั่น oci และการใช้ oci เรียกใช้ Oracle Stored Procedure (IN, OUT)
Rating :
 
ตอนที่ 20 : Visual Basic (VB.Net) เรียกใช้ Oracle Stored Procedure
Rating :
 
ตอนที่ 21 : Java เรียกใช้ Oracle Stored Procedure ด้วย (JDBC)
Rating :
 
ตอนที่ 22 : Visual C# (C# .Net) เรียกใช้ Oracle Stored Procedure
Rating :



ThaiCreate.Com Forum
Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน Struts การเขียนโปรแกรม Java Struts Framework
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน Yii  Framework การเขียนโปรแกรม ภาษา PHP กับ Yii
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว

สุดยอด Source Code V2.0
 

แจ้งชำระเงิน/โอนเงิน
 

Hit Link
   




Acc : thaicreate@hotmail.com






Load balance : Server 03
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2015 All Rights Reserved.
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 084-715-5121 อัตราราคา คลิกที่นี่

Back to Top