在業(yè)務(wù)中經(jīng)常把類型給抽象出來作為一個表,這樣的表有一個特點就是需要經(jīng)常查到,但是基本不用修改到。而這種做法很致命的一點就是作為寫業(yè)務(wù)的程序員必須了解數(shù)據(jù)庫的某條記錄的編號,然后寫進(jìn)去代碼里面,這是完全違反開閉原則的,一旦有修改需要找出所有的代碼并修改。
像下面的代碼:
1 public static String getFilePath(String fileType) {
2 String filePath = "";
3 Integer type = 57;
4 if (null != fileType && !"".equals(fileType)) {
5 type = Integer.parseInt(fileType);
6 }
7 switch (type) {
8 case 53:
9 filePath = "userfiles/images";
10 break;
11 case 54:
12 filePath = "userfiles/video";
13 break;
14 case 55:
15 filePath = "userfiles/audio";
16 break;
17 case 56:
18 filePath = "userfiles/document";
19 break;
20 case 57:
21 filePath = "userfiles/others";
22 break;
23 default:
24 break;
25 }
26 return filePath;
27 }
2 String filePath = "";
3 Integer type = 57;
4 if (null != fileType && !"".equals(fileType)) {
5 type = Integer.parseInt(fileType);
6 }
7 switch (type) {
8 case 53:
9 filePath = "userfiles/images";
10 break;
11 case 54:
12 filePath = "userfiles/video";
13 break;
14 case 55:
15 filePath = "userfiles/audio";
16 break;
17 case 56:
18 filePath = "userfiles/document";
19 break;
20 case 57:
21 filePath = "userfiles/others";
22 break;
23 default:
24 break;
25 }
26 return filePath;
27 }
真正的做法應(yīng)該是將這些脫離于數(shù)據(jù)庫,保存在文件。好處有
1.查詢效率提高N多倍;
2.一旦修改了記錄不用修改源代碼,而源代碼要查找文件,完全符合開閉 原則;
3.讓程序員更容易理清楚關(guān)系,用XML或者其他文件在表示樹等結(jié)構(gòu)上面明顯有優(yōu)勢;
4.修改記錄的成本變得很低,甚至都不用開發(fā)一個軟件來修改了,只要直接編輯文件就是了(當(dāng)然不贊成這樣,不利于權(quán)限管理等)
當(dāng)然,這樣就還有一個問題,程序員需要關(guān)注什么。這里建議用工廠模式。
首先建立一個抽象工廠封裝,將幾種產(chǎn)品的調(diào)用做個封裝,對外提供一個方法,這個方法只需要一個“類型參數(shù)”。就按照上面的例子,可以對外提供images,video,audio等幾個類型參數(shù),所有程序員編程的時候就按照這個分類寫代碼,調(diào)用封裝類以后在進(jìn)行switch條件分支處理。
具體代碼寫多了煩,不寫了。