1. 程式人生 > >MySQL之查漏補缺

MySQL之查漏補缺

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

1、delete語句,是DML語句,truncate語句通常被認為是DDL語句。

2、delete語句,後面可以跟where子句,通常指定where子句中的條件表示式,只刪除滿足條件的部分記錄,而truncate語句,只能用於刪除表中的所有記錄。

3、truncate語句,刪除表中的資料後,向表中新增記錄時,自動增加欄位的預設初始值重新從1開始,而使用delete語句,刪除表中所有記錄後,向表中新增記錄時,自動增加欄位的值,為刪除時該欄位的最大值加1,也就是在原來的基礎上遞增。

4、delete語句,每刪除一條記錄,都會在日誌中記錄,而使用truncate語句,不會在日誌中記錄刪除的內容,因此,truncate語句的執行效率比delete語句高。

安全性:小心使用drop 和truncate,尤其沒有備份的時候.否則哭都來不及。
使用上,想刪除部分資料行用delete,注意帶上where子句. 回滾段要足夠大。
想刪除表,當然用drop
想保留表而將所有資料刪除. 如果和事務無關,用truncate即可. 如果和事務有關,或者想觸發trigger,還是用delete。

2.mysql中的round函式

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

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

這裡有個值得注意的地方是,d可以是負數,這時是指定小數點左邊的d位整數位為0,同時小數位均為0;

2、round(x)  ,其實就是round(x,0),也就是預設d為0;

下面是幾個例項

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

     結果:1123.27

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

     結果: 1123.3

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

     結果:1123

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

     結果: 1120

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

     結果:1100

5、查詢: select round(1123.26723);

     結果:1123

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

 

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

     結果:1123.26

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

     結果: 1123.2

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

     結果:1123

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

     結果: 1120

3、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則不會.

 

四、去重方式以及區別

1.distinct 不會對 table 產生修改,只會返回目標資料(其他欄位的資料也不會返回)

2.group by 將結果的所有欄位資訊返回