MySQL之查漏補缺

1.TRUNCATE語句和DELETE語句的區別

一、delete語句,是DML語句,truncate語句一般被認爲是DDL語句。html

二、delete語句,後面能夠跟where子句,一般指定where子句中的條件表達式,只刪除知足條件的部分記錄,而truncate語句,只能用於刪除表中的全部記錄。mysql

三、truncate語句,刪除表中的數據後,向表中添加記錄時,自動增長字段的默認初始值從新從1開始,而使用delete語句,刪除表中全部記錄後,向表中添加記錄時,自動增長字段的值,爲刪除時該字段的最大值加1,也就是在原來的基礎上遞增。sql

四、delete語句,每刪除一條記錄,都會在日誌中記錄,而使用truncate語句,不會在日誌中記錄刪除的內容,所以,truncate語句的執行效率比delete語句高。數據庫

安全性:當心使用drop 和truncate,尤爲沒有備份的時候.不然哭都來不及。
使用上,想刪除部分數據行用delete,注意帶上where子句. 回滾段要足夠大。
想刪除表,固然用drop
想保留表而將全部數據刪除. 若是和事務無關,用truncate便可. 若是和事務有關,或者想觸發trigger,仍是用delete。安全

2.mysql中的round函數

在mysql中,round函數用於數據的四捨五入,它有兩種形式:函數

一、round(x,d)  ,x指要處理的數,d是指保留幾位小數post

這裏有個值得注意的地方是,d能夠是負數,這時是指定小數點左邊的d位整數位爲0,同時小數位均爲0;spa

二、round(x)  ,其實就是round(x,0),也就是默認d爲0;日誌

下面是幾個實例htm

一、查詢: select round(1123.26723,2);

     結果:1123.27

二、查詢: select round(1123.26723,1);

     結果: 1123.3

三、查詢: select round(1123.26723,0);

     結果:1123

四、查詢: select round(1123.26723,-1);

     結果: 1120

五、查詢: select round(1123.26723,-2);

     結果:1100

五、查詢: select round(1123.26723);

     結果:1123

 ROUND(x,y)函數在截取值的時候會四捨五入,而TRUNCATE(x,y)函數直接截取值,並不進行四捨五入。

 

一、查詢: select truncate(1123.26723,2);

     結果:1123.26

二、查詢: select truncate(1123.26723,1);

     結果: 1123.2

三、查詢: select truncate(1123.26723,0);

     結果:1123

四、查詢: select truncate(1123.26723,-1);

     結果: 1120

三、truncate、drop和delete的區別

1. truncatedelete只刪除數據不刪除表的結構(定義) drop語句將刪除表的結構被依賴的約束(constrain),觸發器(trigger),索引(index); 依賴於該表的 存儲過程/函數將保留,可是變爲invalid狀態. 2.delete語句是dml,這個操做會放到rollback segement中,事務提交以後才生效;若是有相應的trigger, 執行的時候將被觸發. truncate,drop是ddl, 操做當即生效,原數據不放到rollback segment中,不能回滾. 操做不觸發 trigger. 3.delete語句不影響表所佔用的extent, 高水線(high watermark)保持原位置不動 顯然drop語句將表所佔用的空間所有釋放 truncate 語句缺省狀況下見空間釋放到 minextents個 extent,除非使用reuse storage; truncate 會將高水線復位(回到最開始). 4.速度,通常來講: drop> truncate > delete 5.安全性:當心使用drop 和truncate,尤爲沒有備份的時候.不然哭都來不及. 使用上,想刪除部分數據行用delete,注意帶上where子句. 回滾段要足夠大. 想刪除表,固然用drop 想保留表而將全部數據刪除. 若是和事務無關,用truncate便可. 若是和事務有關,或者想觸發trigger,還 是用delete.

若是是整理表內部的碎片,能夠用truncate跟上reuse stroage,再從新導入/插入數據/

 

總結:

DROP用於刪除表,數據庫等.
TRUNCATE和DELETE都是刪除表數據.
可是TRUNCATE至關於初始化,好比若是有自增加ID,用TRUNCATE刪除後,自增加Id會從1開始,(truncat會釋放表所佔的空間)
而delete則不會.

 

4、去重方式以及區別

1.distinct 不會對 table 產生修改,只會返回目標數據(其餘字段的數據也不會返回)

2.group by 將結果的全部字段信息返回

相關文章
相關標籤/搜索