<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    ゞ沉默是金ゞ

    魚離不開水,但是沒有說不離開哪滴水.
    posts - 98,comments - 104,trackbacks - 0

    DELETE

     

    The DELETE command is used to remove rows from a table. A WHERE clause can be used to only remove some rows. If no WHERE condition is specified, all rows will be removed. After performing a DELETE operation you need to COMMIT or ROLLBACK the transaction to make the change permanent or to undo it. Note that this operation will cause all DELETE triggers on the table to fire.

    SQL> SELECT COUNT(*FROM emp;

      
    COUNT(*)
    ----------
            14

    SQL
    > DELETE FROM emp WHERE job = 'CLERK';

    4 rows deleted.

    SQL
    > COMMIT;

    Commit complete.

    SQL
    > SELECT COUNT(*FROM emp;

      
    COUNT(*)
    ----------
            10

    TRUNCATE

     

    TRUNCATE removes all rows from a table. The operation cannot be rolled back and no triggers will be fired. As such, TRUCATE is faster and doesn't use as much undo space as a DELETE.

    SQL> TRUNCATE TABLE emp;

    Table truncated.

    SQL
    > SELECT COUNT(*FROM emp;

      
    COUNT(*)
    ----------
             0

    DROP

     

    The DROP command removes a table from the database. All the tables' rows, indexes and privileges will also be removed. No DML triggers will be fired. The operation cannot be rolled back.

    SQL> DROP TABLE emp;

    Table dropped.

    SQL
    > SELECT * FROM emp;
    SELECT * FROM emp
                  
    *
    ERROR at line 
    1:
    ORA
    -00942table or view does not exist
    DROP and TRUNCATE are DDL commands, whereas DELETE is a DML command. Therefore DELETE operations can be rolled back (undone), while DROP and TRUNCATE operations cannot be rolled back.

     

    From Oracle 10g a table can be "undropped". Example:

     

    SQL> FLASHBACK TABLE emp TO BEFORE DROP;
    
    Flashback complete.

     

    PS: DROP and TRUNCATE are DDL commands, whereas DELETE is a DML command. As such, DELETE operations can be rolled back (undone), while DROP and TRUNCATE operations cannot be rolled back.


    1>TRUNCATE is a DDL command whereas DELETE is a DML command.

    2>TRUNCATE is much faster than DELETE.

    Reason:When you type DELETE.all the data get copied into the Rollback Tablespace first.then delete operation get performed.Thatswhy when you type ROLLBACK after deleting a table ,you can get back the data(The system get it for you from the Rollback Tablespace).All this process take time.But when you type TRUNCATE,it removes data directly without copying it into the Rollback Tablespace.Thatswhy TRUNCATE is faster.Once you Truncate you cann't get back the data.

    3>You cann't rollback in TRUNCATE but in DELETE you can rollback.TRUNCATE removes the record permanently.

    4>In case of TRUNCATE ,Trigger doesn't get fired.But in DML commands like DELETE .Trigger get fired.

    5>You cann't use conditions(WHERE clause) in TRUNCATE.But in DELETE you can write conditions using WHERE clause
    6>TRUNCATE command resets the High Water Mark for the table but DELETE does not. So after TRUNCATE the operations on table are much faster.

    posted on 2012-07-12 15:30 ゞ沉默是金ゞ 閱讀(698) 評論(0)  編輯  收藏 所屬分類: DB
    主站蜘蛛池模板: 三级毛片在线免费观看| 乱爱性全过程免费视频| 222www免费视频| 久久久久亚洲av无码尤物| 中文在线免费看视频| 中文字幕亚洲综合久久菠萝蜜| 一级做a爱片特黄在线观看免费看| 全部免费毛片在线| 色多多A级毛片免费看| 国产成人亚洲影院在线观看| 国产精品成人啪精品视频免费| 亚洲一区二区三区影院| 成全高清在线观看免费| 亚洲Av综合色区无码专区桃色 | 成人网站免费看黄A站视频| 曰韩亚洲av人人夜夜澡人人爽| 成人精品一区二区三区不卡免费看| 亚洲熟妇av一区二区三区 | aaa毛片免费观看| 久久精品国产亚洲AV果冻传媒 | 国产精品99精品久久免费| 亚洲国产精品网站久久| 成人激情免费视频| 人碰人碰人成人免费视频| 亚洲精品国产字幕久久不卡 | 毛片A级毛片免费播放| 免费人成视频在线播放| 国产精品亚洲A∨天堂不卡 | 97视频免费在线| 国产精品亚洲综合网站| 亚洲无线观看国产精品| 免费看成人AA片无码视频羞羞网| 亚洲av永久中文无码精品| 亚洲色精品88色婷婷七月丁香 | 免费a级毛片视频| 久久精品无码精品免费专区| 亚洲成_人网站图片| 国产L精品国产亚洲区久久| 成人免费的性色视频| 一道本不卡免费视频| 亚洲色图古典武侠|