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