<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 ゞ沉默是金ゞ 閱讀(696) 評論(0)  編輯  收藏 所屬分類: DB
    主站蜘蛛池模板: 亚洲黄色免费电影| 日韩免费视频一区二区| 免费无码黄动漫在线观看| 亚洲av产在线精品亚洲第一站| 人妻无码久久一区二区三区免费 | 95老司机免费福利| 亚洲精品综合一二三区在线 | 亚洲福利一区二区精品秒拍| 99久久99久久精品免费观看| 亚洲成人免费电影| 最近高清国语中文在线观看免费| 亚洲精品中文字幕无乱码麻豆| 最近中文字幕无吗高清免费视频| 亚洲国产精华液2020| 亚洲国产日韩成人综合天堂| 中文毛片无遮挡高清免费| 午夜亚洲AV日韩AV无码大全| xx视频在线永久免费观看| 亚洲精品伦理熟女国产一区二区| 免费a级毛片在线观看| 久久久久久国产a免费观看不卡 | 国产精品免费久久久久电影网| 亚洲gv白嫩小受在线观看| 91精品国产免费入口| 亚洲老熟女五十路老熟女bbw| 亚洲人成人无码网www国产| 久9久9精品免费观看| 国产婷婷综合丁香亚洲欧洲| 日韩亚洲精品福利| 日韩电影免费观看| 亚洲午夜无码久久久久软件| 亚洲精品国产精品乱码不卡| 三年片在线观看免费观看大全动漫| 亚洲a级片在线观看| 亚洲日韩涩涩成人午夜私人影院| 亚欧免费无码aⅴ在线观看| 精品久久久久久亚洲中文字幕| 国产亚洲成av人片在线观看| 成年女人免费视频播放体验区| 黄色视频在线免费观看| 亚洲日本久久久午夜精品|