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