<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
    主站蜘蛛池模板: 久久99国产乱子伦精品免费| a级毛片高清免费视频就| 午夜性色一区二区三区免费不卡视频| 亚洲精品成人片在线观看精品字幕 | 色婷婷7777免费视频在线观看| 亚洲一区二区三区首页| 久久久免费的精品| 亚洲美女视频网站| 美女视频黄免费亚洲| 国产成人精品亚洲日本在线| 美女视频黄a视频全免费| 亚洲va精品中文字幕| 久久久www成人免费毛片| 亚洲乱码av中文一区二区| 日本不卡视频免费| 黄页网站在线视频免费| 亚洲一区二区三区无码中文字幕| 国内精品99亚洲免费高清| 91亚洲导航深夜福利| 在线观看AV片永久免费| 国产精品亚洲AV三区| 国产av无码专区亚洲国产精品| 免费人成网站在线观看不卡| 亚洲精品美女视频| 永久免费无码网站在线观看| 精品久久久久久无码免费| 91情国产l精品国产亚洲区| 中文字幕无码免费久久99| 特级aa**毛片免费观看| 久久香蕉国产线看观看亚洲片| 四虎在线免费视频| 精品女同一区二区三区免费播放| 亚洲免费观看视频| 成人免费看片又大又黄| 国产高清对白在线观看免费91| 亚洲美女aⅴ久久久91| 四虎影在线永久免费四虎地址8848aa | 日本媚薬痉挛在线观看免费| 中文无码日韩欧免费视频| 亚洲成a人片在线网站| 亚洲av片一区二区三区|