ORACLE ¶¯Ì¬Óï¾ä
ÔÚÒ»°ãµÄPL/SQL³ÌÐò¿ª·¢ÖУ¬¿ÉÒÔʹÓÃSQLµÄDMLÓï¾äºÍÊÂÎñ¿ØÖÆÓï¾ä£¬µ«ÊÇDDLÓï¾ä¼°»á»°Óï¾äÈ´²»ÄÜÔÚPL/SQLÖÐÖ±½ÓʹÓã¬ÒªÏëʵÏÖÔÚPL/SQLÖÐʹÓÃDDLÓï¾ä¼°»á»°¿ØÖÆÓï¾ä£¬¿ÉÒÔͨ¹ý¶¯Ì¬SQLÀ´ÊµÏÖ¡£
Ëùν¶¯Ì¬SQLÊÇÖ¸ÔÚPL/SQL¿é±àÒëʱSQLÓï¾äÊDz»È·¶¨µÄ£¬ÀýÈç¸ù¾ÝÓû§ÊäÈë²ÎÊýµÄ²»Í¬¶øÖ´Ðв»Í¬µÄ²Ù×÷¡£±àÒë³ÌÐò¶Ô¶¯Ì¬Óï¾ä²¿·Ö²»½øÐд¦Àí£¬Ö»ÊÇÔÚ³ÌÐòÔËÐÐʱ¶¯Ì¬µØ´´½¨Óï¾ä£¬¶ÔÓï¾ä½øÐÐÓï·¨·ÖÎö²¢Ö´ÐиÃÓï¾ä¡£ ORACLEÖеĶ¯Ì¬SQL¿ÉÒÔͨ¹ý±¾µØ¶¯Ì¬SQLÃüÁîÀ´Ö´ÐУ¬Ò²¿ÉÒÔͨ¹ýDBMS_SQL³ÌÐò°üÀ´Ö´ÐС£
ͨ³£ÔÚ¿ª·¢ÖÐÓüòµ¥µÄ±¾µØ¶¯Ì¬SQL¾ÍÄܽâ¾öÎÊÌ⣬ÔÚÏÂÃæÎÒ»áÓñðµÄ·½·¨À´ÊµÏÖ¡£¸ø³öÖ´Ðб¾µØ¶¯Ì¬SQLµÄÓï·¨£º
EXECUTE IMMEDIATE dynamic_sql_string [INTO define_variable_list] [USING bind_argument_list];
ÆäÖУº dynamic_sql_string ÊǶ¯Ì¬SQLÓï¾ä×Ö·û´® INTO×Ó¾äÓÃÓÚ½ÓÊÜSELECTÓï¾äÑ¡ÔñµÄ¼Í¼ֵ¡£ USING×Ó¾äÓÃÓÚ½ÓÊܰó¶¨ÊäÈë²ÎÊý±äÁ¿¡£
Àý×Ó1:
DECLARE
sql_s varchar2(200);
emp_id number(4):=7566;
emp_rec emp%rowtype;
BEGIN
EXECUTE IMMEDIATE 'create table table_name (id number,amt number)';
sql_s:='select * from emp where empno=:id;
EXECUTE IMMEDIATE sql_s into emp_rec using emp_id;
END;
Õâ¶Î´úÂëÊ×ÏÈÖ´ÐÐÒ»Ìõ´´½¨µÄ¶¯Ì¬SQL,½Ó×ÅÖ´ÐÐÁË´ø²ÎÊýµÄSELECTÓï¾ä¡£EXECUTE IMMEDIATEÓï¾äÖ»ÄÜÓÃÓÚ´¦Àí·µ»Øµ¥ÐлòûÓзµ»ØµÄSQLÓï¾ä£¬Òª´¦Àí·µ»Ø¶àÐеĶ¯Ì¬SQL¾ÍҪʹÓÃREFÓαêµÄOPEN...FORÓï¾ä¡£ÏÂÃæ¾ÍÀ´ÌÖÂÛ£º
Àý2£º
ÒªÇó£ºÓû§ÊäÈë¶à¸öÅú´ÎºÅ(lot_number)ºÍÎïÁϺÅ(key_number )»ò¶à¸öÅú´ÎºÅ(lot_number)ºÍ¹©Ó¦ÉÌÃû(ver_apell)À´Çó¿â´æÖÐÎïÁϵÄÊýĿΪÁËÈôúÂë½á¹¹ÇåÎú£¬ÎÒʹÓðüÀ´´´½¨´úÂ룺
Ê×ÏÈ£¬´´½¨°üÍ·²¿·Ö£º
create or replace package SMT_Traceability_p is
&n
Ïà¹ØÎĵµ£º
Ò»£¬PL/SQL¿éµÄ½á¹¹ºÍ×é³ÉÔªËØ
PL/SQL³ÌÐòÓÉÉùÃ÷²¿·Ö£¬Ö´Ðв¿·Ö£¬Òì³£´¦Àí²¿·ÖÈý¸ö²¿·Ö×é³É¡£½á¹¹ÈçÏ£º
DECLARE
/*ÉùÃ÷²¿·Ö£ºÔÚ´ËÉùÃ÷PL/SQL±äÁ¿£¬ÀàÐͼ°Óα꣬ÒÔ¼°¾Ö²¿µÄ´æ´¢¹ý³ÌºÍº¯Êý*/
BEGIN
/*Ö´Ðв¿·Ö£º¹ý³Ì¼°sqlÓï¾ä£¬³ÌÐòÖ÷Òª²¿·Ö£¬ÊDZØÐëµÄ*/
EXCEPTION
/*Òì³£´¦Àí²¿·Ö£º´íÎó´¦Àí*/
END
PL/SQL¿ ......
4¡¢¶ÔÏóÒÀÀµÐÔ
CREATE OR REPLACE TYPE Obj1 AS OBJECT (
f1 NUMBER,
f2 VARCHAR2(10),
f3 DATE
);
/
CREATE OR REPLACE TYPE Obj2 AS OBJECT (
f1 DATE,
f2 CHAR(1)
);
/
CREATE OR REPLACE TYPE Obj3 AS OBJECT (
a Obj1,
b Obj2
);
/
OBJ3ÒÀÀµÓÚOBJ ......
7¡¢¶ÔÏóÀàÐͼ̳Ð
¶ÔÏóÀàÐÍʵÏÖÔÊÐíÎÒÃÇ´´½¨Ò»¸ö»ùÀàÐÍ£¬»ò½Ð¸¸ÀàÐÍ£¬ÕâÖÖÀàÐ͵ÄÊôÐÔ»ò·½·¨¿ÉÒÔ±»ÁíÒ»¸ö¶ÔÏóÀàÐͼ̳С£È»ºó¿ÉÒÔ´´½¨Ò»¸ö×ÓÀàÐÍ£¬»ò½Ðº¢×ÓÀàÐÍ£¬Ö±½ÓʹÓü̳йýÀ´µÄÊôÐÔ»ò·½·¨£¬»òÕßÓÃ×Ô¼ºµÄÊôÐԺͷ½·¨ÖØÐ´¸¸ÀàÐ͵ÄÊôÐÔ»ò·½·¨¡£
INSTANTIABLE¹Ø¼ü×Ö±íʾÎÒÃÇ¿ÉÒÔ´Ó¸ÃÀàÐÍÖÐʵÀý»¯»òÕß´´½¨¶ÔÏ ......
1. create table people (age int, id int);
2. ´´½¨Êý¾ÝÎļþPeopleDate.txt.
Êý¾ÝΪ£º
20,1
30,2
3. ´´½¨ ......
ORACLEÏà¹ØÓï·¨ ÊÕ²Ø
Ò»¡¢OracleÈëÃÅ
ÀíÂÛ֪ʶ£º
OracleµÄÎïÀí×é¼þÓÐÈý¸ö£º
(1)Êý¾ÝÎļþ Êý¾ÝÎļþÊÇÓÃÓÚ´æ´¢Êý¾Ý¿âÊý¾ÝµÄÎļþ£¬Èç±í¡¢Ë÷ÒýÊý¾Ý¡£Ã¿¸öOracleÊý¾Ý¿âÓÐÒ»¸ö»ò¶à¸öÎïÀíÊý¾ÝÎļþ£¬
&nbs ......