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. truncate和 delete只刪除資料不刪除表的結構(定義) 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 將結果的所有欄位資訊返回