<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无码国产精品色午友在线| 国产免费av片在线无码免费看| ZZIJZZIJ亚洲日本少妇JIZJIZ| 亚洲精品无码久久久久牙蜜区| 我的小后妈韩剧在线看免费高清版| 久久久无码精品亚洲日韩蜜臀浪潮| 最近免费字幕中文大全| 亚洲伊人久久成综合人影院| free哆拍拍免费永久视频 | 又粗又大又黑又长的免费视频| 亚洲久本草在线中文字幕| 最近2019中文免费字幕在线观看 | 成年男女免费视频网站| 亚洲中文字幕无码爆乳app| 国产一精品一AV一免费孕妇| 国产成+人+综合+亚洲专| 亚洲成AV人片在线观看无| 成全动漫视频在线观看免费高清版下载| 亚洲午夜国产精品无码老牛影视| 中文字幕免费人成乱码中国| 久久精品国产亚洲网站| 91高清免费国产自产拍2021| 亚洲高清日韩精品第一区| 特级做A爰片毛片免费69| 久久亚洲精品11p| 国产成人麻豆亚洲综合无码精品 | 丁香六月婷婷精品免费观看| 中文亚洲AV片在线观看不卡| 日韩免费无码视频一区二区三区| 亚洲成a人片在线网站| 在线看片免费不卡人成视频| 国产精品亚洲综合天堂夜夜| 国产aⅴ无码专区亚洲av麻豆| 69视频在线观看高清免费| 亚洲国产精品日韩av不卡在线| 亚洲欧洲中文日韩久久AV乱码| 国产va在线观看免费| 色偷偷女男人的天堂亚洲网| 亚洲第一区精品观看| 特级精品毛片免费观看| 国产亚洲精彩视频|