ѧϰ¡¶Oracle 9i10g±à³ÌÒÕÊõ¡·µÄ±Ê¼Ç (ʮһ) ÊÂÎñ
1.ÊÂÎñ¸ÅÊö
ÊÂÎñ£¨Transaction£©ÊÇÊý¾Ý¿âÇø±ðÓÚÎļþϵͳµÄÌØÐÔÖ®Ò»¡£ÔÚÎļþϵͳÖУ¬Èç¹ûÄãÕý°ÑÎļþдµ½Ò»
°ë£¬²Ù×÷ϵͳͻȻ±ÀÀ£ÁË£¬Õâ¸öÎļþ¾ÍºÜ¿ÉÄܻᱻÆÆ»µ¡£²»´í£¬È·Êµ»¹ÓÐһЩ“ÈÕ±¨Ê½”£¨journaled£©Ö®
ÀàµÄÎļþϵͳ£¬ËüÃÇÄÜ°ÑÎļþ»Ö¸´µ½Ä³¸öʱ¼äµã¡£²»¹ý£¬Èç¹ûÐèÒª±£Ö¤Á½¸öÎļþͬ²½£¬ÕâЩÎļþϵͳ¾ÍÎÞ
ÄÜΪÁ¦ÁË¡£ÌÈÈôÄã¸üÐÂÁËÒ»¸öÎļþ£¬ÔÚ¸üÐÂÍêµÚ¶þ¸öÎļþ֮ǰ£¬ÏµÍ³Í»È»Ê§°ÜÁË£¬Äã¾Í»áÓÐÁ½¸ö²»Í¬²½µÄ
Îļþ¡£
ÕâÊÇÊý¾Ý¿âÖÐÒýÈëÊÂÎñµÄÖ÷ҪĿµÄ£ºÊÂÎñ»á°ÑÊý¾Ý¿â´ÓÒ»ÖÖÒ»ÖÂ״̬ת±äΪÁíÒ»ÖÖÒ»ÖÂ״̬¡£Õâ¾ÍÊÇ
ÊÂÎñµÄÈÎÎñ¡£ÔÚÊý¾Ý¿âÖÐÌá½»¹¤×÷ʱ£¬¿ÉÒÔÈ·±£ÒªÃ´ËùÓÐÐ޸Ķ¼ÒѾ±£´æ£¬ÒªÃ´ËùÓÐÐ޸Ķ¼²»±£´æ¡£ÁíÍ⣬
»¹Äܱ£Ö¤ÊµÏÖÁ˱£»¤Êý¾ÝÍêÕûÐԵĸ÷ÖÖ¹æÔòºÍ¼ì²é¡£
ÔÚÉÏÒ»ÕÂÖУ¬ÎÒÃÇ´Ó²¢·¢¿ØÖƽǶÈÌÖÂÛÁËÊÂÎñ£¬²¢ËµÃ÷ÁËÔڸ߶Ȳ¢·¢µÄÊý¾Ý·ÃÎÊÌõ¼þÏ£¬¸ù¾ÝOracle
µÄ¶à°æ±¾¶ÁÒ»ÖÂÄ£ÐÍ£¬Oracle ÊÂÎñÿ´ÎÈçºÎÌṩһÖµÄÊý¾Ý¡£Oracle ÖеÄÊÂÎñÌåÏÖÁËËùÓбØÒªµÄACID ÌØ
Õ÷¡£ACID ÊÇÒÔÏÂ4 ¸ö´ÊµÄËõд£º
Ô×ÓÐÔ£¨atomicity£©£ºÊÂÎñÖеÄËùÓж¯×÷Ҫô¶¼·¢Éú£¬ÒªÃ´¶¼²»·¢Éú¡£
Ò»ÖÂÐÔ£¨consistency£©£ºÊÂÎñ½«Êý¾Ý¿â´ÓÒ»ÖÖÒ»ÖÂ״̬ת±äΪÏÂÒ»ÖÖÒ»ÖÂ״̬¡£
¸ôÀëÐÔ£¨isolation£©£ºÒ»¸öÊÂÎñµÄÓ°ÏìÔÚ¸ÃÊÂÎñÌύǰ¶ÔÆäËûÊÂÎñ¶¼²»¿É¼û¡£
³Ö¾ÃÐÔ£¨durability£©£ºÊÂÎñÒ»µ©Ìá½»£¬Æä½á¹û¾ÍÊÇÓÀ¾ÃÐԵġ£
2.ÊÂÎñ¿ØÖÆÓï¾ä
Oracle Öв»ÐèҪרÃŵÄÓï¾äÀ´“¿ªÊ¼ÊÂÎñ”¡£Òþº¬µØ£¬ÊÂÎñ»áÔÚÐÞ¸ÄÊý¾ÝµÄµÚÒ»ÌõÓï¾ä´¦¿ªÊ¼£¨Ò²¾Í
Êǵõ½TX ËøµÄµÚÒ»ÌõÓï¾ä£©¡£Ò²¿ÉÒÔʹÓÃSET TRANSACTION »òDBMS_TRANSACTION °üÀ´ÏÔʾµØ¿ªÊ¼Ò»¸öÊÂÎñ£¬
µ«ÊÇÕâÒ»²½²¢²»ÊDZØÒªµÄ£¬ÕâÓëÆäËûµÄÐí¶àÊý¾Ý¿â²»Í¬£¬ÒòΪÄÇЩÊý¾Ý¿âÖж¼±ØÐëÏÔʽµØ¿ªÊ¼ÊÂÎñ¡£Èç¹û
·¢³öCOMMIT »òROLLBACK Óï¾ä£¬¾Í»áÏÔʽµØ½áÊøÒ»¸öÊÂÎñ¡£
×¢ÒâROLLBACK TO SAVEPOINT ÃüÁî²»»á½áÊøÊÂÎñ£¡ÕýÈ·µØдΪROLLBACK£¨Ö»ÓÐÕâÒ»¸ö´Ê£©²ÅÄܽáÊø
ÊÂÎñ¡£
Ò»¶¨ÒªÏÔʽµØʹÓÃCOMMIT »òROLLBACK À´ÖÕÖ¹ÄãµÄÊÂÎñ¡£
COMMIT£ºÒªÏëʹÓÃÕâ¸öÓï¾äµÄ×î¼òÐÎʽ£¬Ö»Ðè·¢³öCOMMIT¡£Ò²¿ÉÒÔ¸üÏêϸһЩ£¬Ð´ÎªCOMMIT
WORK£¬²»¹ýÕâ¶þÕßÊǵȼ۵ġ£COMMIT »á½áÊøÄãµÄÊÂÎñ£¬²¢Ê¹µÃÒÑ×öµÄËùÓÐÐ޸ijÉΪÓÀ¾ÃÐԵģ¨³Ö
¾Ã±£´æ£©¡£COMMIT Óï¾ä»¹ÓÐһЩÀ©Õ¹ÓÃÓÚ·Ö²¼Ê½ÊÂÎñÖС£ÀûÓÃÕâЩÀ©Õ¹£¬ÔÊÐíÔö¼ÓһЩÓÐÒâÒåµÄ
×¢ÊÍΪCOMMIT ¼Ó±êÇ©£¨¶ÔÊÂÎñ¼Ó±êÇ©£©£¬ÒÔ¼°Ç¿µ÷Ìá½»Ò»¸ö¿ÉÒɵķֲ¼Ê½ÊÂÎñ¡£
ROLLBACK£ºÒªÏëʹÓÃÕâ¸öÓï¾äµÄ×î¼òÐÎÊ
Ïà¹ØÎĵµ£º
Oracle Ö÷ÒªÅäÖÃÎļþ½éÉÜ£º
profileÎļþ£¬oratab Îļþ£¬Êý¾Ý¿âʵÀý³õʼ»¯Îļþ initSID.ora£¬¼àÌýÅäÖÃÎļþ£¬ sqlnet.ora Îļþ£¬tnsnames.ora Îļþ
1.2 Oracle Ö÷ÒªÅäÖÃÎļþ½éÉÜ
1.2.1 /etc/profile Îļþ
ϵͳ¼¶µÄ»·¾³±äÁ¿Ò»°ãÔÚ/etc/p ......
--´´½¨Ò»¸ö°ü
create or replace package types
as
type cursorType is ref cursor;
end types;
--´´½¨´æ´¢¹ý³Ì,ÓαêÀàÐÍ·µ»Ø²ÎÊý
create or replace procedure SP_Fee_Instance(v_company in varchar, v_sdate in nva ......
RedoµÄÄÚÈÝ
Oracleͨ¹ýRedoÀ´ÊµÏÖ¿ìËÙÌá½»£¬Ò»·½ÃæÊÇÒòΪRedo Log File¿ÉÒÔÁ¬Ðø¡¢Ë³ÐòµØ¿ìËÙд³ö£¬ÁíÒ»¸ö·½ÃæÒ²ºÍRedo¼Ç¼µÄ¾«¼òÄÚÈÝÓйء£
Á½¸ö¸ÅÄ
¸Ä±äÏòÁ¿£¨Change Vector£©
¸Ä±äÏòÁ¿±íʾ¶ÔÊý¾Ý¿âÄÚijһ¸öÊý¾Ý¿éËù×öµÄÒ»´Î±ä¸ü¡£¸Ä±äÏòÁ¿Öаüº¬Á˱ä¸üµÄÊý¾Ý¿éµÄ°æ±¾ºÅ¡¢ÊÂÎñ²Ù×÷´úÂë¡¢±ä¸ü´ÓÊôÊý¾Ý¿éµÄµØÖ·£¨DBA£ ......
Èç¹û˵RedoÊÇÓÃÀ´±£Ö¤ÔÚ¹ÊÕÏʱÊÂÎñ¿ÉÒÔ±»»Ö¸´£¬ÄÇôUndoÔòÊÇÓÃÀ´±£Ö¤ÊÂÎñ¿ÉÒÔ±»»ØÍË»òÕß³·Ïú¡£
ÔÚÐ޸IJÙ×÷ÖУ¬¶ÔÓÚ»ØÍ˶εIJÙ×÷´æÔڶദ£¬ÔÚÊÂÎñ¿ªÊ¼Ê±£¬Ê×ÏÈÐèÒªÔڻعö¶Î±í¿Õ¼ä»ñµÃÒ»¸öÊÂÎñ²Û£¬·ÖÅä¿Õ¼ä£¬È»ºó´´½¨Ç°¾µÏñ£¬´ËºóÊÂÎñµÄÐ޸IJÅÄܽøÐУ¬Oracle±ØÐëÒÔ´ËÀ´±£Ö¤ÊÂÎñÊÇ¿ÉÒÔ»ØÍ˵ġ£
Èç¹ûÓû§Ìá½»ÁËÊÂÎñ£¬Oracle»á ......
ÔÎĵØÖ·£ºhttp://hi.baidu.com/zengjl/blog/item/c06c8edeb2c7e45cccbf1aca.html/cmtid/305a850ea57b09ec37d1226c
1.²éѯ±íÊý¾Ý
SQL> select deptno,ename,sal
2 from emp
3 order by deptno;
DEPTNO ENAME SAL
......