ORACLE¸´Ï°(¶þ)
Èý¡¢ PL/SQL³ÌÐòµ¥Ôª
1¡¢ÎÞÂÛÊǵ¥¶ÀµÄ¹ý³Ì/º¯Êý£¬»¹ÊǰüÖеĹý³Ì/º¯Êý£¬¶¼Í³³ÆÎª×Ó³ÌÐò¡£
2¡¢¹ý³Ì
1) Òì³£´¦Àí²¿·ÖÊÇ¿ÉÑ¡µÄ¡£
2) ¹ý³ÌÃûÓ¦¸ÃÓö¯´Ê£¬ÒòΪ¹ý³Ìͨ³£ÊÇÖ´ÐÐijÖÖ¶¯×÷¡£¹ý³Ì²¢²»Ò»¶¨¾ßÓвÎÊý¡£µ±´´½¨µÄ¹ý³ÌûÓвÎÊý£¬¾Í²»ÐèҪʹÓÃÔ²À¨ºÅ¡£µ±µ÷Óùý³Ìʱ£¬¿ÕÀ¨ºÅÊÇ¿ÉÑ¡µÄ¡£È磺PROCEDURE insert_temp IS
BEGIN
INSERT INTO temp(n) VALUES(0);
END insert_temp;
Ôòµ÷ÓÃʱ£¬¿ÉÒÔ²ÉÓÃinsert_temp;»òÕßinsert_temp();
3) ¾¡¹Ü½«¹ý³ÌÃû×·¼Óµ½END×Ó¾äºóÊÇ¿ÉÑ¡µÄ£¬µ«Ç¿ÁÒÍÆ¼öÕâô×ö£»³£¼ûµÄ¹ý³ÌÑùʽÊÇIS¡¢BEGIN¡¢EXCEPTIONºÍEND¶ÔÆë¡£ÕâЩ¹Ø¼ü×Ö×÷ÓÃÓòÄÚµÄÈ«²¿´úÂë¶¼Òª½øÐÐËõ½ø¡£ÕâÑùÓÐÖúÓÚ³ÌÐòµÄ¿É¶ÁÐÔ¡£
3¡¢º¯Êý
1) º¯Êý²»ÊǶ¯×÷Õߣ¬¶øÊÇ״̬µÄ¼ÆËãÖµ£¬ËùÒÔ¸ÃÓÃÃû´Ê¶Ôº¯Êý½øÐÐÃüÃû
2) ²ÎÊýÊÇ¿ÉÑ¡µÄ£¬µ«ÊÇRETURNÓï¾äÊDZØÐëµÄ¡£Èç¹ûº¯Êý·µ»ØÖµÀàÐÍÓëij±äÁ¿ÀàÐÍÏàͬ£¬Ôò¸Ã±äÁ¿Ó뺯Êýµ÷ÓÃÖ®¼äÊÇ¿ÉÒÔ»¥»»µÄ¡£
4¡¢°ü
1) ×î»ù±¾µÄ°ü¹æ·¶Óï·¨ÊÇ£º
CREATE PACKAGE package_name IS
Type definition for records, index_by tables,varrys, nested tables
Constants
Exceptions
Global variable declarations
PROCEDURE procedure_name_1(parameters & types);
PROCEDURE procedure_name_2(parameters & types);
FUNCTION function_name_1(parameters &types) RETURN type;
END package_name;
2) °ü¹æ·¶ÖпÉÒÔÉùÃ÷Êý¾ÝÀàÐÍ£¨È磬¼Ç¼ÀàÐÍ£©¡¢Êý¾ÝÉùÃ÷£¨È磬¼Ç¼£©ºÍÒì³£¡£ÔÚ°ü¹æ·¶ÖÐÉùÃ÷µÄËùÓÐÊý¾Ý¶ÔÏó¶¼ÊÇÈ«¾ÖµÄ¡£ËùÒÔÔÚ°ü¹æ·¶ÖÐÉùÃ÷µÄ±äÁ¿Ó¦µ±Ö»ÊÇÄÇЩ×÷ÓÃÓòÊÇÈ«¾ÖµÄ±äÁ¿¡£°üÌåÖеÄPROCEDUREÓï¾ä±ØÐëÓëÏàÓ¦°ü¹æ·¶ÖеÄPROCEDUREÓï¾äÏàÆ¥Å䣬°üÀ¨×Ó³ÌÐòÃû³Æ¡¢²ÎÊýÃû³Æ¡¢²ÎÊýģʽºÍ²ÎÊýÀàÐ͵ȡ£Í¬ÑùÊÊÓÃÓÚFUNCTION×Ó³ÌÐò¡£
5¡¢²ÎÊýÓëģʽ
IN(ĬÈÏ), IN OUT, OUT
IN±íÃ÷×Ó³ÌÐòÖ»Äܽ«¸Ã²ÎÊý×÷Ϊһ¸ö±äÁ¿À´Ê¹Óã¬ËüÊÇÖ»¶Á
IN OUT²ÎÊýÖ»ÄÜÊDZäÁ¿ÀàÐÍ£¬²»ÔÊÐíΪÎÄ×Ö»ò³
Ïà¹ØÎĵµ£º
Ìí¼ÓÒýÓÃ
using System.Data.OracleClient;
Ö÷ÒªÓõ½ÁËÁ½¸öÀà
System.Data.OracleClient.OracleConnection ±íʾһ¸öµ½Êý¾Ý¿âµÄÁ¬½Ó¡£´ËÀàÎÞ·¨¼Ì³Ð¡£
System.Data.OracleClient.OracleCommand ±íʾÕë¶ÔÊý¾Ý¿âÖ´ÐÐµÄ SQL Óï¾ä»ò´æ ......
create or replace directory MY_DIR as '/usr/test/';
create or replace function f_exportTxt(
--´«Èë²ÎÊý
i_query in varchar2,
i_separator in varchar2,
i_dir in varchar2,
i_filename in varchar2
) return number
is
/**
** º¯ÊýÃû:f_exportTxt
&nbs ......
t±íÖн«½üÓÐ1100ÍòÊý¾Ý£¬ºÜ¶àʱºò£¬ÎÒÃÇÒª½øÐÐ×Ö·û´®Æ¥Å䣬ÔÚSQLÓï¾äÖУ¬ÎÒÃÇͨ³£Ê¹ÓÃlikeÀ´´ïµ½ÎÒÃÇËÑË÷µÄÄ¿±ê¡£µ«¾¹ýʵ¼Ê²âÊÔ·¢
ÏÖ£¬likeµÄЧÂÊÓëinstrº¯Êý²î±ðÏ൱´ó¡£ÏÂÃæÊÇһЩ²âÊÔ½á¹û£º
SQL> set timing on
SQL> select count(*) from t where instr(title,’ÊÖ²á’)>0;
COUNT(*)
&mdash ......
ORACLEÖеÄÊý¾Ý×ÖµäÊÇʲô£¿ÓÐÊ²Ã´ÌØµãºÍ¹æÂÉ£¿
Êý¾Ý×Öµä¼Ç¼ÁËÊý¾Ý¿âµÄϵͳÐÅÏ¢£¬ËüÊÇÖ»¶Á±íºÍϵͳÊÓͼµÄ¼¯ºÏ¡£
Êý¾Ý×ÖµäµÄËùÓÐÕßÊÇSYSÓû§£¬Êý¾Ý×ֵ䶼±»´æ·ÅÔÚSYSTEM±í¿Õ¼ä£¬SYSÓû§µÄ·½°¸Ï¡£
Êý¾Ý×ÖµäÖ»ÔÊÐíSELECT²Ù×÷£¬Æäά»¤ºÍÐÞ¸ÄÈÎÎñÓÉÊý¾Ý¿â×Ô¶¯Íê³É¡£
µ±Óû§Ö´ÐÐCREATE¡¢ALTER¡¢DROP ......