資料庫開發管理中的十條建議

來源:互聯網
上載者:User

因為主要管理資料庫平台,所以和公司各個部門的相關技術人員都打過不少交道,然後從日常溝通中,瞭解到不少技術人員對資料庫的觀念,有正確的,有錯誤的,今天就列一些常見的錯誤觀念:

1,發現鎖表嚴重情況,會立刻想到改用Innodb,好像Innodb的行級鎖之後,就不會表鎖了,持這種觀念的開發人員不在少數,其實他們不知道在做排序或是where條件複雜的情況下,一樣會產生表鎖。

2, 發現磁碟IO過大,會立刻想到分表,(這個方向是好的),但是一問,結果是分幾千張表,認為這樣之後,磁碟IO壓力就會下降,其實分表並不能解決磁碟IO,結合分庫+分表,然後分擔到不同的物理機器,這樣才能真正做到拆分,降低磁碟IO。

3, 大部分應用開發人員都會對錶名定義的很通俗,如user,其實這樣做不好,因為在進行抓包分析時候,這種沒有特徵的表名會導致故障排查變難。

4, 大部分應用開發人員不喜歡定時清理曆史資料,只管存,不管清,導致項目資料量達到一定程度,再跑清理程式時候會比較影響服務。

5, 有些應用開發人員缺乏對錶資料欄位的控制,一個表放100多個欄位,超級恐怖。

6,還有的應用開發人員乾脆把表定義的超級多mediutext,拿資料庫當儲存用了,而且是冷熱資料都放一起,搞得偶很無語。

7,應用開發人員經常會跑一些奇怪的join,嵌套子查詢的SQL,但是卻不去explain一下到底會有多大的掃描集,我見過有跑到上億掃描集的。

8,對MySQL的觸發器過於依賴,但是不考慮如果在誤操作之後的恢複操作,會產生商務邏輯的混亂。

9,很多技術開發人員一聽重要如收費相關的項目,就是想要用Innodb的事務機製做保障,其實真沒必要,我管的項目中收費讀書和英超收費頻道都是用myisam的,跑了快2年了,至今沒發現有使用者要告公司收費不準的問題。

10,很多開發人員喜歡在SQL語句使用Now()這樣的語句,其實應該盡量讓PHP程式去獲得時間。因為當你通過binlog進行誤操作恢複時候,你就能體會我說的意思了。

  1. InnoDB還是MyISAM 再談MySQL儲存引擎的選擇
  2. 詳解MySQL三項實用開發知識
  3. 使用DB2必須瞭解的幾個知識點

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.