ORACLE PL/SQL
Ò»¡¢Ê²Ã´ÊÇPL/SQL?
PL/SQL(Procedural Language/SQL)ÊǶÔSQLµÄÀ©³ä,ËüÎüÊÕÁ˽üÄêÀ´±à³ÌÓïÑÔµÄÐí¶à×î¸ßÉè¼ÆÌØµã:ÈçÊý¾Ý·â×°ÐÔ¡¢ÐÅÏ¢Òþ±ÎÐÔ¡¢ÖØÔغÍÀýÍâ´¦ÀíµÈ¡£ËüÔÊÐíSQLµÄÊý¾Ý²Ù×ÝÓïÑԺͲéѯÓï¾ä°üº¬ÔÚ¿é½á¹¹(block_structured)ºÍ´úÂë¹ý³ÌÓïÑÔÖÐ,ʹPL/SQL³ÉΪһ¸ö¹¦ÄÜÇ¿´óµÄÊÂÎñ´¦ÀíÓïÑÔ¡£
PL/SQLµÄÓŵãÈçÏÂ:
1.¿é½á¹¹(Block Structure)
PL/SQLÊÇ¿é½á¹¹ÓïÑÔ,Òâζ×ųÌÐò¿ÉÒÔ·Ö³ÉÈô¸ÉÂß¼¿é,¸÷×Ô°üº¬ÄǸöµ¥ÔªÀïÒªÇóµÄÂß¼ÓïÑÔ×ÊÔ´¡£¿ÉÒÔ¶Ô¿éÐû²¼±¾µØ±äÁ¿£¬ÔÚ¿éÖÐʹÓÃÕâЩ±äÁ¿,¿ÉÔÚËüÃÇÓ¦ÓõĿéÖÐÌØ±ðµØ´¦Àí´íÎóÌõ¼þ(½Ð×öExceptions)
2. Á÷³Ì¿ØÖÆ
Ìõ¼þÓï¾ä¡¢Ñ»·ºÍ·ÖÖ§¿ÉÓÃÀ´¿ØÖƳÌÐòµÄ¹ý³ÌÁ÷£¬ÒÔ¾ö¶¨ÊÇ·ñ»òºÎʱִÐÐSQL»òÆäËüÐж¯¡£ÕâÐ©ÌØµãÔÊÐíORACLE¹¤¾ß(ÖîÈçSQL*Forms)È¥·Ö×éÁªÏµÔÚÒ»ÆðµÄÃüÁî×éºÍͨ¹ýPL/SQL¿ØÖÆËüÃǵÄÖ´ÐС£ÕâÑù¿ÉÒÔ±ÜÃâÖÃÐí¶àÃüÁîΪµ¥¶ÀµÄ´¥·¢Æ÷²½Öè»òÕßǶÌ×Íⲿ±à³ÌÓïÑÔÖеÄSQLÓï¾äµÄÒªÇó¡£
3. ¿ÉÒÆÖ²ÐÔ
ÒòΪPL/SQLÊÇORACLEµÄÖ÷ÓïÑÔ,¹Ê³ÌÐò¿ÉÒÆÖ²ÖÁÖ§³ÖORACLEºÍPL/SQLµÄÈκβÙ×÷ϵͳƽ̨ÉÏ¡£
4.¼¯³ÉÐÔ
PL/SQLÔÚRDBMS(´æÖü¹ý³Ì¡¢´¥·¢Æ÷¡¢°ü)ºÍORACLE¹¤¾ßÖаçÑÝÁËÈÕÒæÔö³¤µÄÖÐÐĽÇÉ«¡£PL/SQLµÄ±äÁ¿ºÍÐÍÓëSQLµÄ±äÁ¿ºÍÐͼæÈÝ(Óë×Ô¼ºÓÃÔÚÊý¾Ý¿âÁÐÖеÄÐÍÒ²¼æÈÝ)¡£Òò´Ë£¬PL/SQLÊÇÁ¬½ÓÊý¾Ý¿â¼¼ÊõºÍ¹ý³Ì±à³ÌÄÜÁ¦Ö®¼ä¼ä϶µÄ·½±ãµÄÇÅÁº¡£
5. ¸Ä½øÁËÐÔÄÜ
PL/SQLµÄʹÓÿÉÒÔ°ïÖú¸Ä½øÓ¦ÓóÌÐòµÄÐÔÄÜ¡£ÔÚûÓÐPL/SQLʱ,ORACLEÿ´ÎÖ»´¦ÀíÒ»¸öSQLÓï¾ä,¶øÔÚ¾ßÓÐPL/SQLʱ,Ò»¸öÍêÕûµÄÓï¾ä¿éÒ»´Î·¢Ë͵½ORACLE,¿ÉÃ÷ÏԵؼõÉÙÓëORACLEÖ®¼äµÄͨÐź͵÷Óá£Ìá¸ßÁËÐ§Òæ¡£Ð§ÒæµÄ²îÒìÈ¡¾öÓÚPL/SQLʹÓõÄʲô»·¾³¡£ÕâÐ©Ð§ÒæÉÔºóÌÖÂÛ¡¡
¶þ¡¢PL/SQLµÄ½á¹¹
PL/SQLµÄÿ¸öµ¥ÔªÓÉÒ»¸ö»ò¶à¸ö¿é(blocks)×é³É¡£ÕâЩ¿é¿ÉÒÔÊÇÍêÈ«¶ÀÁ¢µÄ,»òÕßÒ»¸ö¿éǶÌ×ÔÚÁíÒ»¸ö¿éÖ®ÖС£ÕâÑù,Ò»¸ö¿é¿É±íʾÆäËü¿éµÄһС²¿·Ö,·´¹ýÀ´,ËüÇ¡ºÃÒ²ÊÇÕû¸ö³ÌÐòÂëµ¥ÔªµÄÒ»²¿·Ö¡£
ͨ³£,Ò»¸ö¿é¿ÉÒÔÊÇÎÞÃû¿é»òÕßÒ»¸ö×Ó³ÌÐò¡£
1. ÎÞÃû¿é(anonymous)
ÎÞÃû¿éÊÇÒ»ÖÖûÓÐÃû×ֵĿ顣ÕâЩ¿éÔÚÔËÐÐËüÃǵÄÓ¦ÓóÌÐòÖÐ˵Ã÷£¬²¢ÇÒΪÁËÖ´ÐÐÔÚÔËÐÐʱÓÉPL/SQLÒýÇæÍ¨¹ý¡£ÎÞÃû¿é¿ÉÒÔǶÈëÔ¤±àÒë³ÌÐò(»òOCI³ÌÐò)¡¢ÒÔ¼°SQL*PLUS»òSQL*DBAÖС£SQL*FormsÖеĴ¥·¢Æ÷Ò²ÓÉÕâЩ¿é×é³É,ÎÞÃû¿éÓõý϶ࡣ
ÎÞÃû¿éµÄ¶¨ÒåÐÎʽΪ:
DECLARE
--˵Ã÷
BEGIN
--Óï¾äÐòÁÐ
[EXCEPT
Ïà¹ØÎĵµ£º
oracle±í¿Õ¼ä²Ù×÷Ïê½â
1
2
3×÷Õߣº À´Ô´£º ¸üÐÂÈÕÆÚ£º2006-01-04
5
6
7½¨Á¢±í¿Õ¼ä
8
9CREATE TABLESPACE data01
10DATAFILE '/ora ......
extent--×îС¿Õ¼ä·ÖÅ䵥λ --tablespace management
block --×îСi/oµ¥Î» --segment management
create tablespace james
datafile '/export/home/oracle/oradata/james.dbf'
size 100M ¡¡¡¡¡¡¡¡¡¡¡¡--³õʼµÄÎļþ´óС¡¡
autoextend On¡¡¡¡¡¡¡¡ --×Ô¶¯Ôö³¤
next 10M¡ ......
-- ²éѯij±íµÄÊý¾Ý×Öµä
SELECT A.TABLE_NAME AS "±íÃû",A.COLUMN_NAME AS "×Ö¶ÎÃû",
DECODE(A.CHAR_LENGTH,0,DECODE(A.DATA_SCALE,NULL,A.DATA_TYPE,A.DATA_TYPE||'('||A.DATA_PRECISION||','||A.DATA_SCALE||')'),
A.DATA_TYPE||'('||A.CHAR_LENGTH||')') as "×Ö¶ÎÀàÐÍ1",A.DATA_TYPE AS "×Ö¶Î ......
Ò»¡¢ oracle»ù´¡ÖªÊ¶
a¡¢ CRUD²Ù×÷ create read update delete
b¡¢ Êý¾Ý¿â¶ÔÏó
c¡¢ Êý¾Ý¿âÉè¼Æ
d¡¢ Êý¾Ý¿â½á¹¹ÌåϵÓÅ»¯£¨DBA£©
oracleÖдæÔÚËÄÕÅÁ·Ï°±í emp dept slmgad bonus ÕâËÄÕÅ±í£¬»¹ÓÐÒ»ÕÅdual±íÁ·Ï°±í±íÖÐÖ»ÓÐÒ»¸ö×Ö¶ÎÒ»¸öÊý ......
ÔÎĵØÖ·£ºhttp://www.blogjava.net/xingcyx/archive/2007/01/09/92638.html
ʹÓÃoracleµÄ10046ʼþ¸ú×ÙSQLÓï¾ä
ÎÒÃÇÔÚ·ÖÎöÓ¦ÓóÌÐòÐÔÄÜÎÊÌâµÄʱºò£¬¸ü¶àµØÐèÒª¹Ø×¢ÆäÖÐSQLÓï¾äµÄÖ´ÐÐÇé¿ö£¬ÒòΪͨ³£Ó¦ÓóÌÐòµÄÐÔÄÜÆ¿¾±»áÔÚÊý¾Ý¿âÕâ±ß£¬Òò´ËÊý¾Ý¿âµÄsqlÓï¾äÊÇÎÒÃÇÓÅ»¯µÄÖØµã¡£ÀûÓÃOracleµÄ10046ʼþ£¬¿ÉÒÔ¸ú×ÙÓ¦ÓóÌÐòËùÖ´ ......