<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
    主站蜘蛛池模板: 成年人视频免费在线观看| 亚洲婷婷国产精品电影人久久| 久草视频在线免费| 亚洲av日韩综合一区在线观看| 国产福利免费视频| 亚洲综合激情另类专区| 国产人成网在线播放VA免费| 久久久久亚洲AV成人网人人网站| 成年免费大片黄在线观看com| 日韩插啊免费视频在线观看| 国产精品无码素人福利免费 | 全亚洲最新黄色特级网站 | 精品免费tv久久久久久久| 久久久久亚洲av成人无码电影 | 91久久精品国产免费一区| 亚洲免费在线视频| 免费观看国产网址你懂的| 亚洲入口无毒网址你懂的| 中文字幕永久免费视频| 亚洲日韩中文无码久久| 精品亚洲福利一区二区| 麻豆视频免费观看| 亚洲xxxxxx| 中文字幕成人免费视频| 亚洲乱码中文论理电影| 黄网址在线永久免费观看 | 亚洲欧洲免费无码| 亚洲αv久久久噜噜噜噜噜| 香蕉成人免费看片视频app下载| 亚洲美女色在线欧洲美女| 二个人看的www免费视频| 亚洲色图黄色小说| 国产婷婷高清在线观看免费 | 国产成人yy免费视频| 久久久久久久久无码精品亚洲日韩| 国产L精品国产亚洲区久久| 67194成手机免费观看| 亚洲AV永久无码区成人网站| 国产在线观看片a免费观看| 又硬又粗又长又爽免费看| 久久亚洲AV成人无码软件|