PL/SQL È¡µÃɾ³ý¼Í¼µÄÌõÊý
ÔõÑùͳ¼ÆPLSQLÓïÑÔÖÐɾ³ýÓï¾äÖ´ÐÐÖ®ºóÒ»¹²É¾³ýÁ˶àÉÙÌõ¼Í¼¡£
OracleʹÓÃÁ½ÖÖ¹â±ê£ºÏÔʽ¹â±êºÍÒþʽ¹â±ê¡£²»¹ÜÓï¾ä·µ»Ø¶àÉÙÌõ¼Í¼£¬PL/SQLΪʹÓõÄÿһÌõUPDATE¡¢DELETEºÍINSERTµÈSQLÃüÁîÒþʽµÄÉùÃ÷Ò»¸ö¹â±ê¡££¨Òª¹ÜÀíSQLÓï¾äµÄ´¦Àí£¬±ØÐëÒþʽµÄ¸øËü¶¨ÒåÒ»¸ö¹â±ê¡££©
ÔÚPL/SQLÖУ¬µ±Ö´ÐÐDMLÓï¾äµÄʱºò£¬»á×Ô¶¯´ò¿ªÒ»¸öÒþʽÓα꣨Óαê¾ÍÀàËÆJDBCÖеÄResultSet£©£¬¶øÏà¹ØÒª±»²Ù×÷µÄÊý¾Ý¶¼ÊÇ»áÏȱ»·ÅÈëÒþʽÓαꡣÒþʽÓαêÓÉORACLE°ïÎÒÃÇ×Ô¶¯¹ÜÀí£¬Èç¹ûÏëÒªÊÖ¶¯½øÐÐһЩ²Ù×÷µÄ»°£¬ÎÒÃÇ¿ÉÒÔʹÓÃÒþʽÓαêµÄÏà¹ØÊôÐÔ¡£È磺
SQL%FOUND ³É¹¦»ñÈ¡¼Ç¼·µ»Øtrue,·ñÔò·µ»Øfalse
SQL%NOTFOUND ³É¹¦»ñÈ¡¼Ç¼·µ»Øtrue,·ñÔò·µ»Øfalse
SQL%ROWCOUNT ·µ»Ø´ÓÓαêÖлñÈ¡µÄ¼Ç¼ÌõÊý
SQL%ISOPEN ×ÜÊÇ·µ»Øfalse
ÀûÓÃÒþʽÓαêÊôÐÔSQL%ROWCOUNT¿ÉÒÔ´ïµ½¼ÆËãɾ³ýÁ˶àÉÙÌõ¼Í¼¡£
dbms_output.put_line('¿ªÊ¼É¾³ý'||v_score||'ÒÔϵÄͬѧ');
DELETE from t_student WHERE s_score<v_score; --ɾ³ý±ÈÊäÈëµÄ³É¼¨¶¼ÒªÉÙµÄѧÉú
IF SQL%FOUND THEN --Èç¹û¿ÉÒÔ´ÓÒþʽÓαêÖлñµÃÊý¾ÝÔò·µ»Øtrue
dbms_output.put_line('ɾ³ýÁË'||SQL%ROWCOUNT||'¸öѧÉú'); --SQL%ROWCOUNT-ɾ³ýµÄѧÉúµÄ¼Ç¼ÌõÊý
ELSE --Èç¹û²»ÄÜ´ÓÒþʽÓαêÖлñµÃÊý¾ÝÔò·µ»Øfalse
dbms_output.put_line('ûÓÐɾ³ý¼Ç¼');
END IF;
²Î¿¼
http://www.haoxiai.net/wangzhanzhizuo/shujuku/61234.html
http://blog.sina.com.cn/s/blog_610239f40100gow4.html
Ïà¹ØÎĵµ£º
TOM´óÊåµÄµ÷ÓÅÊéÖÐ˵¹ýÒ»¾ä»°£¬¾ßÌåÓ¢ÎľÍÍüÁË£¬´ó¸ÅÒâ˼¾ÍÊÇ£ºÈç¹ûÓÐÈËÈÃÎÒд±¾ÔõÑùÈÃORACLEÐÔÄÜ×îÂýµÄÊéµÄ»°ÎһὫȡÏû°ó¶¨±äÁ¿(bind variable)×öΪÊéµÄµÚÒ»ÕºÍ×îºóÒ»ÕÂ(ËûµÄÒâ˼ÊÇËûºÜÓÐÓÄĬ~~!)£¬¿É¼û°ó¶¨±äÁ¿µÄÖØÒªÐÔ¡£
°ó¶¨±äÁ¿´ó¶àÓÃÔÚOLTP(online transaction process)ÖУ¬ÔÚOLAP(online analizy process)ÖоÍû± ......
1¡¢²é¿´±í¿Õ¼äµÄÃû³Æ¼°´óС
¡¡¡¡select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size
¡¡¡¡from dba_tablespaces t, dba_data_files d
¡¡¡¡where t.tablespace_name = d.tablespace_name
¡¡¡¡group by t.tablespace_name;
¡¡¡¡
¡¡¡¡2¡¢²é¿´±í¿Õ¼äÎïÀíÎļþµÄÃû³Æ¼°´óС
¡¡¡¡select tablespace_ ......
CLR Óû§¶¨Ò庯ÊýÖ»ÊÇÔÚ .NET ³ÌÐò¼¯Öж¨ÒåµÄ¾²Ì¬·½·¨¡£CREATE FUNCTION Óï¾äÒÑÀ©Õ¹ÎªÖ§³Ö´´½¨ CLR
Óû§¶¨Ò庯Êý¡£
1¡¢´´½¨Êý¾Ý¿âÏîÄ¿
¡¡¡¡
2¡¢Ìí¼ÓÓû§¶¨Ò庯Êý
¡¡¡¡
ÒÔÏÂÊÇÑÝʾ´úÂ룺
Code
using
System;
using
System.Data;
using
System.Data.SqlClient;
using
System.Data.Sql ......
µÝ¹éµÄͨÓñí±í´ïʽ
µÝ¹éµÄCTEÊǸù¾ÝÖÁÉÙÁ½¸ö²éѯ£¨»òÕß³ÆÎªÁ½¸ö³ÉÔ±£©¹¹½¨µÄ£¬Ò»¸öÊǷǵݹé²éѯ£¬Ò²³ÉΪ¹Ì¶¨³ÉÔ±£¬Ö»Äܵ÷ÓÃÒ»´Î£¬ÁíÍâÒ»¸öÊǵݹé²éѯ£¬Ò²³ÉΪµÝ¹é³ÉÔ±£¨RM£©£¬¿ÉÒÔ·´¸´µ÷Óã¬Ö±µ½²éѯ²»ÔÙ·µ»ØÐС£²éѯÓÉUNION ALLÔËËã·ûÁ¬½ÓΪһ¸öµ¥¶ÀµÄCTE¡£
--ʹÓõݹéµÄͨÓñí±í´ïʽ
GO
CREATE TABLE CarParts
( ......
DDL´¥·¢Æ÷ DDL Triggers
SQL Server 2005¿ÉÒÔ¾ÍÕû¸ö·þÎñÆ÷»òÊý¾Ý¿âµÄij¸ö·¶Î§ÎªDDLʼþ¶¨Òå´¥·¢Æ÷¡£Ò²¿ÉÒÔΪµ¥¸öDDLÓï¾ä£¨ÀýÈ磺CREAT_TABLE¡¢DROP_TABLEµÈ£©»òÕßΪһ×éÓï¾ä£¨ÀýÈ磺ָ¶¨DDL_DATABASE_LEVEL_EVENTSÏëÒª´¥·¢Æ÷´¥·¢Êý¾Ý¿âËùÓÐDDLʼþ£©¶¨ÒåDDL´¥·¢Æ÷¡£
ÔÚDDL´¥·¢Æ÷ÄÚ²¿£¬¿ÉÒÔͨ¹ý·ÃÎÊeventdata()º¯Êý»ñµÃÓ ......