1. 選取適合的字段屬性
為了獲取更好的性能,可以將表中的字段寬度設(shè)得盡可能小。
盡量把字段設(shè)置成not null
執(zhí)行查詢的時候,數(shù)據(jù)庫不用去比較null值。
對某些省份或者性別字段,將他們定義為enum類型,enum類型被當(dāng)做數(shù)值型數(shù)據(jù)來處理,而數(shù)值型數(shù)據(jù)被處理起來的速度要比文本類型塊很多。
2. 使用join連接代替子查詢
3. 使用聯(lián)合union來代替手動創(chuàng)建的臨時表
union用法中,兩個select語句的字段類型要匹配,而且字段個數(shù)要相同。
4. 事務(wù)
要么都成功,要么都失敗。
可以保證數(shù)據(jù)庫中數(shù)據(jù)的一致性和完整性。事務(wù)以begin開始,commit關(guān)鍵字結(jié)束。
如果出錯,rollback命令可以將數(shù)據(jù)庫恢復(fù)到begin開始之前的狀態(tài)。
事務(wù)的另一個重要作用是當(dāng)多個用戶同時使用相同的數(shù)據(jù)源時,它可以利用鎖定數(shù)據(jù)庫的方式為用戶提供一種安全的訪問方式,這樣就可以保證用戶的操作不被其他的用戶干擾。
5. 鎖定表
盡管事務(wù)是維護(hù)數(shù)據(jù)庫完整性的一個非常好的方法,但卻因?yàn)樗莫?dú)占性,有時會影響數(shù)據(jù)庫的性能,尤其是在大應(yīng)用中。
由于在事務(wù)執(zhí)行的過程中,數(shù)據(jù)庫會被鎖定,因此其它用戶只能暫時等待直到事務(wù)結(jié)束。
有的時候可以用鎖定表的方法來獲得更好的性能。
共享鎖:其它用戶只能看,不能修改
lock table person in share mode;
對于通過lock table 命令主動添加的鎖來說,如果要釋放它們,只需發(fā)出rollback命令即可。
6. 使用外鍵
鎖定表的方法可以維護(hù)數(shù)據(jù)的完整性,但是它卻不能保證數(shù)據(jù)的關(guān)聯(lián)性,這個時候可以使用外鍵。
7. 使用索引
索引是提高數(shù)據(jù)庫查詢速度的常用方法,尤其是查詢語句中包含max()、min()、order by這些命令的時候,性能提高更為顯著。
一般來說索引應(yīng)該建在常用于join、where、order by的字段上。盡量不要對數(shù)據(jù)庫中含有大量重復(fù)的值得字段建立索引。
8. 優(yōu)化的查詢語句
在索引的字段上盡量不要使用函數(shù)進(jìn)行操作。
盡量不要使用like關(guān)鍵字和通配符,這樣做法很簡單,但卻是以犧牲性能為代價的。
避免在查詢中進(jìn)行自動類型轉(zhuǎn)換,因?yàn)轭愋娃D(zhuǎn)換也會使索引失效。