国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 如何對數據庫進行優化?

如何對數據庫進行優化?

來源:千鋒教育
發布人:qyf
時間: 2022-09-21 15:59:51 1663747191

如何對數據庫進行優化

  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關鍵字和通配符,這樣做法很簡單,但卻是以犧牲性能為代價的。

  避免在查詢中進行自動類型轉換,因為類型轉換也會使索引失效。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT