青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 45  文章 - 129  trackbacks - 0
<2007年2月>
28293031123
45678910
11121314151617
18192021222324
25262728123
45678910

專注于C++ P2P STL GP OpenSource等
Google

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

相冊

朋友

  • .NET

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

引言

在開發(fā)Web應(yīng)用系統(tǒng)中,用戶管理是一個核心的問題。管理用戶,必不可少要管理用戶的聯(lián)系方式。一般情況下,人們會建立一個專門的聯(lián)系方式表,包含電話、Email、QQMSN等聯(lián)系方式。不難發(fā)現(xiàn),即便我們考慮得再周全,也無法羅列全部的聯(lián)系方式,如手機(jī)、座機(jī)、小靈通、大靈通、skype等。那么,如何才能使用戶能夠自由添加各種聯(lián)系方式而不會影響系統(tǒng)本身呢?讓我們來探討這個問題的解決。

 

一、直接在用戶表中增加聯(lián)系方式字段

我們最先在管理用戶的時候,會直接在用戶表后面添加聯(lián)系方式,如下表:

 

用戶名

單位

phone

email

張三

A公司

01012345678

aa@163.com

(表1

 

這在用戶張三只有一個電話和一個Email地址的情況下,沒有問題。但是,有一天,張三買了一個手機(jī),并且把手機(jī)作為一種很重要的聯(lián)系方式。開發(fā)人員很直觀的想法就是在后面再加一個字段Mobile

 

用戶名

單位

phone

email

Mobile

張三

A公司

01012345678

aa@163.com

13912345678

(表2

 

顯而易見,這需要對用戶表進(jìn)行修改。這會為上層的程序帶來麻煩。為了防止對用戶表的修改,單獨(dú)建立一個用戶聯(lián)系方式表是很自然的。

 

二、聯(lián)系方式表與用戶信息表分離

于是上面的用戶表改變成下面兩個表。

 

用戶信息表

用戶ID

用戶名

單位

1

張三

A公司

2

李四

B公司

(表3

 

聯(lián)系方式表

ID

phone

Email

Mobile

用戶ID

1

01012345678

aa@163.com

13912345678

1

2

02033333333

bb@gmail.com

13688888888

2

(表4

 

這樣一來,如果某一天又新增了一種聯(lián)系方式,比如即時聊天工具QQMSN,我們無需改動用戶信息表,只需要在聯(lián)系方式表中增加相應(yīng)字段就可以了。

是不是這樣就已經(jīng)令人滿意了呢?

 

三、聯(lián)系方式表擴(kuò)展性問題

現(xiàn)在我們有一個新的用戶名號王五,他既沒有手機(jī)號,也沒有Email,他只想留下QQ號作為聯(lián)系方式?,F(xiàn)在的表就變成這樣:

 

用戶信息表

用戶ID

用戶名

單位

1

張三

A公司

2

李四

B公司

3

王五

C公司

(表5

 

聯(lián)系方式表

ID

phone

Email

Mobile

QQ

用戶ID

1

01012345678

aa@163.com

13912345678

 

1

2

02033333333

bb@gmail.com

13688888888

 

2

3

 

 

 

232678

3

(表6

 

由于張三和李四輸入信息時并沒有QQ這一字段,所以張三、李四的聯(lián)系方式記錄的QQ字段的內(nèi)容是空的。而王五的聯(lián)系方式只有QQ這一字段有內(nèi)容,其它幾個字段都是空的。

現(xiàn)在,我們已經(jīng)看出這種方式的問題了:

第一,         聯(lián)系方式表中會一些字段的內(nèi)容是空的,這會造成數(shù)據(jù)空間的浪費(fèi)。

第二,         每增加一種聯(lián)系方式,我們都需要在聯(lián)系方式表中增加字段。這會使系統(tǒng)的維護(hù)變得非常復(fù)雜,還可能導(dǎo)致上層應(yīng)用程序包括界面進(jìn)行相應(yīng)的修改。

 

于是我們便期望有一種更好的方法,能夠解決聯(lián)系方式擴(kuò)充的問題,即:用戶能夠根據(jù)自己的需要添加聯(lián)系方式,同時又不需要對數(shù)據(jù)庫結(jié)構(gòu)進(jìn)行修改。

 

四、根據(jù)要素來構(gòu)建聯(lián)系方式表

好的,問題提出來了,我們就著手進(jìn)行改進(jìn)。先來進(jìn)行一下理論的探討:

聯(lián)系方式是指聯(lián)系一個人的手段或途徑,聯(lián)系方式最核心的要素是:方式+ 。即采用什么樣的聯(lián)系方式,這種聯(lián)系方式的具體值是多少。如手機(jī)作為一種聯(lián)系方式,值就是手機(jī)號碼。QQ也可以作為一種聯(lián)系方式,QQ號碼就是聯(lián)系方式的值。

 

從邏輯上講,聯(lián)系方式表的結(jié)構(gòu)應(yīng)該由其要素構(gòu)成。即聯(lián)系方式表的字段應(yīng)該以方式和值作為最基本內(nèi)容。

而我們上面建立的聯(lián)系方式表,將phone、EmailMobile、QQ等作為表的字段。而phone、Email等都是聯(lián)系方式的內(nèi)容,并不是聯(lián)系方式表的要素本身。這是導(dǎo)致聯(lián)系方式表不靈活的根本原因。

那么,現(xiàn)在我們就真正按照聯(lián)系方式表的要素來搭建結(jié)構(gòu),而將Phone、Email等作為內(nèi)容。

現(xiàn)在的聯(lián)系方式表應(yīng)該是這樣:

 

ID

聯(lián)系方式

1

Phone

13912345678

2

Email

aa@163.com

(表7

 

這樣我們就可以隨意添加聯(lián)系方式到表中了。當(dāng)然,由于聯(lián)系方式都是與用戶對應(yīng)的,所以聯(lián)系方式表中還應(yīng)該包含一個用戶ID字段,即:

 

ID

聯(lián)系方式

用戶ID

1

Phone

13912345678

1 (張三的用戶ID

2

Email

aa@163.com

1

3

Phone

02033333333

2(李四的用戶ID)

4

Email

bb@gmail.com

2

5

QQ

232678

3(王五的用戶ID

(表8

 

這樣,用戶信息表與聯(lián)系方式表就構(gòu)成了一對多的關(guān)系。當(dāng)然,這需要一種聯(lián)系方式不是由兩個人同時擁有,這也是與現(xiàn)實(shí)比較相符的。

 

五、讓表結(jié)構(gòu)更加優(yōu)雅

前面的問題已經(jīng)解決,我們是不是應(yīng)該去喝慶功酒去了呢?

且慢,仔細(xì)看看最后的聯(lián)系方式表(表8),有沒有發(fā)現(xiàn)什么問題?在聯(lián)系方式字段中,我們看到了兩個Phone,兩個Email。如果用戶更多,看到的PhoneEmail可能還會更多。

在錄入數(shù)據(jù)的時候,會不會出現(xiàn)兩個Phone不一致的情況,如一個首字母大寫,一個首字母小寫?當(dāng)然,你會回答,可以在錄入數(shù)據(jù)時一律進(jìn)行大小寫轉(zhuǎn)換。

好吧,那個問題就此打住。我還有另一個問題:如果我想把Phone改成SitePhone,應(yīng)該怎么辦?做一次遍歷,然后進(jìn)行替換?

更好的方式:將聯(lián)系方式這個字段單獨(dú)取出來,建立另一個表,不但能解決剛才提出的這個問題,而且會收到更好的效果,請看:

 

ID

聯(lián)系方式

1

Phone

2

Email

3

QQ

(表9

 

ID

聯(lián)系方式ID

用戶ID

1

1

13912345678

1 (張三的用戶ID

2

2

aa@163.com

1

3

1

02033333333

2(李四的用戶ID)

4

2

bb@gmail.com

2

5

3

232678

3(王五的用戶ID

(表10

 

這樣做有什么好處呢?第一,聯(lián)系方式Phone、Email、QQ等在數(shù)據(jù)庫中只出現(xiàn)了一次,便于對這些聯(lián)系方式進(jìn)行修改,也有利于保持?jǐn)?shù)據(jù)的一致性。第二、可以對每種聯(lián)系方式附加一些屬性,如聯(lián)系方式的用戶數(shù),這種統(tǒng)計數(shù)字可以用來分析用戶群體使用聯(lián)系方式的特征,從而改進(jìn)商業(yè)策略。

 

好了,最后我們把建立的最終表呈現(xiàn)在下面吧:

 

1、用戶信息表

用戶ID

用戶名

單位

1

張三

A公司

2

李四

B公司

3

王五

C公司

(表11

 

2、聯(lián)系方式表

ID

聯(lián)系方式

數(shù)量

1

Phone

2

2

Email

2

3

QQ

1

(表12

 

3、用戶聯(lián)系信息管理表

ID

聯(lián)系方式ID

用戶ID

1

1

13912345678

1

2

2

aa@163.com

1

3

1

02033333333

2

4

2

bb@gmail.com

2

5

3

232678

3

(表13

 

六、題外話

就設(shè)計用戶聯(lián)系方式表這一簡單的話題,我們一路走來。筆者認(rèn)為,由表及里地思考對于我們設(shè)計可擴(kuò)展的、易于維護(hù)的數(shù)據(jù)庫系統(tǒng)非常有好處,可以為后續(xù)的管理、維護(hù)以及升級帶來不少便利,省下不少精力和時間。我們的這種思考可以舉一反三應(yīng)用到選課數(shù)據(jù)庫設(shè)計、用戶權(quán)限管理數(shù)據(jù)庫設(shè)計等方面。

當(dāng)然,我們可以再上升到理論的層次:前面所做的工作事實(shí)上是對數(shù)據(jù)庫設(shè)計的正規(guī)化形式的體現(xiàn)。如果對數(shù)據(jù)庫進(jìn)行正規(guī)化設(shè)計,請參閱我的另一篇筆記:http://blog.csdn.net/z365days/archive/2007/10/25/1842608.aspx

posted on 2007-10-30 10:26 CPP&&設(shè)計模式小屋 閱讀(823) 評論(2)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)庫

FeedBack:
# re: 建立動態(tài)可擴(kuò)展的聯(lián)系方式(轉(zhuǎn)自博客http://blog.csdn.net/z365days/) 2007-10-30 14:47 蔡蔡
剛讀研究生的時候,我在曾經(jīng)的非常小型的項目里就用這種方式處理聯(lián)系人信息,信息靈活的一個代價就是在展現(xiàn)層多寫了許多許多的代碼來對應(yīng)擴(kuò)展性,另外當(dāng)時使用的是access數(shù)據(jù)庫,沒有存儲過程,又在數(shù)據(jù)訪問層寫了很多的代碼來保證數(shù)據(jù)完整性和正確性?,F(xiàn)在回頭看,在那么小的應(yīng)用環(huán)境下也進(jìn)行職責(zé)拆分多少有點(diǎn)過度設(shè)計的味道,雖然那個版本的通訊錄從功能上和交互性上都比之前的版本好了許多,但是也因為涉及多表的一些問題,加上當(dāng)年的稚嫩,開發(fā)和測試周期都延長了一些,呵呵  回復(fù)  更多評論
  
# re: 建立動態(tài)可擴(kuò)展的聯(lián)系方式(轉(zhuǎn)自博客http://blog.csdn.net/z365days/) 2008-04-15 13:43 tzqdo@163.com
但是性能上的影響大不大呢?因為要查詢至少三個表  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
      <noscript id="pjuwb"></noscript>
            <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
              <dd id="pjuwb"></dd>
              <abbr id="pjuwb"></abbr>
              欧美老女人xx| 国产欧美日韩一区二区三区| 欧美成人一品| 国产字幕视频一区二区| 亚洲小视频在线观看| 亚洲电影在线看| 亚洲欧美日韩在线| 欧美午夜精品久久久久久浪潮| 精久久久久久| 久久久久欧美| 欧美亚洲网站| 国产精品一区免费观看| 亚洲午夜电影网| 一二三区精品福利视频| 欧美日韩国产一区| 一本大道久久精品懂色aⅴ| 欧美高清在线视频| 欧美99久久| 日韩系列欧美系列| 亚洲精品日韩激情在线电影| 欧美激情综合网| 99精品视频免费在线观看| 亚洲精品美女免费| 国产精品久久77777| 欧美在线视频全部完| 欧美一区二区三区四区夜夜大片| 国产视频久久| 欧美xxx成人| 欧美成人在线网站| 亚洲深夜福利| 亚洲综合国产激情另类一区| 国产麻豆精品在线观看| 久久久久久久久蜜桃| 久久久亚洲高清| 亚洲人体一区| 在线亚洲伦理| 国模精品一区二区三区| 欧美**人妖| 欧美日本韩国一区二区三区| 欧美一区二区三区视频在线观看 | 亚洲视频一起| 亚洲一区二区成人在线观看| 国产一区二区按摩在线观看| 欧美成人中文字幕在线| 欧美激情一区二区三区高清视频| av成人毛片| 午夜精品福利视频| 91久久精品一区| 亚洲在线不卡| 亚洲国产乱码最新视频| av成人动漫| 黄色成人精品网站| 99国产精品国产精品久久| 国产午夜精品久久久久久免费视| 亚洲福利视频专区| 国产欧美三级| 亚洲精品欧美极品| 午夜精品影院在线观看| 免费亚洲一区| 亚洲欧美一区在线| 免费黄网站欧美| 午夜亚洲福利| 欧美精品在线一区| 欧美中文字幕第一页| 欧美日韩成人在线视频| 久久亚洲精品网站| 国产精品国产a级| 免费观看在线综合色| 国产精品三级视频| 99热免费精品| 亚洲狠狠婷婷| 久久高清福利视频| 亚洲欧美日韩国产一区| 欧美成人一品| 欧美sm视频| 国际精品欧美精品| 亚洲自拍另类| 亚洲一区二区三区四区视频| 欧美gay视频激情| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品jvid在线观看蜜臀| 亚洲激情图片小说视频| 亚洲电影网站| 久久精品成人欧美大片古装| 午夜精品久久久久久久久久久| 欧美ab在线视频| 欧美v亚洲v综合ⅴ国产v| 在线观看国产日韩| 久久久久久久久久久久久久一区| 欧美一区二区三区另类| 国产精品一区2区| 亚洲在线视频| 欧美一区二区三区播放老司机| 国产精品久久久久久久免费软件| 99香蕉国产精品偷在线观看| 宅男精品导航| 欧美日韩三级视频| 亚洲日本一区二区三区| 日韩亚洲在线观看| 欧美精品色一区二区三区| 亚洲精品久久久一区二区三区| 99国产一区| 欧美天天在线| 亚洲免费在线视频| 久久久国产精彩视频美女艺术照福利| 国产精品一区免费观看| 欧美自拍偷拍| 欧美成人第一页| 亚洲精品女av网站| 欧美色大人视频| 午夜精品福利一区二区三区av| 久久久久9999亚洲精品| 亚洲福利免费| 欧美日韩国内| 欧美一级黄色录像| 欧美不卡在线视频| 亚洲最新中文字幕| 国产精品视频成人| 久久精品论坛| 亚洲人成网站999久久久综合| 亚洲无毛电影| 狠狠色丁香久久婷婷综合_中| 欧美jjzz| 午夜精品短视频| 欧美黄在线观看| 亚洲图中文字幕| 狂野欧美激情性xxxx欧美| 亚洲国产片色| 欧美精品久久一区二区| 亚洲午夜影视影院在线观看| 久久久国产精品一区二区中文 | 欧美日韩精品一区二区天天拍小说| 一本久久a久久精品亚洲| 久久动漫亚洲| 99热这里只有精品8| 国产亚洲一区精品| 欧美日韩a区| 欧美在线网站| 亚洲青色在线| 久久视频在线看| 亚洲天堂视频在线观看| 在线免费精品视频| 国产精品五月天| 欧美激情按摩| 久久久久五月天| 亚洲午夜羞羞片| 亚洲丶国产丶欧美一区二区三区| 亚洲欧美一区二区三区久久| 亚洲激情在线观看| 国产亚洲精品美女| 国产精品成人国产乱一区| 毛片基地黄久久久久久天堂| 午夜老司机精品| 一区二区三区视频在线观看| 欧美激情一区二区三区成人| 久久久999国产| 午夜精品免费在线| 一区二区三区欧美在线观看| 亚洲国产精品久久久久秋霞影院| 国产欧美 在线欧美| 国产精品嫩草影院av蜜臀| 欧美三级午夜理伦三级中文幕| 欧美韩日视频| 快播亚洲色图| 久久精品欧美| 久久精品成人一区二区三区蜜臀| 午夜视频在线观看一区二区| 99在线视频精品| 亚洲国产精品欧美一二99| 欧美福利电影网| 欧美ab在线视频| 欧美成人一区二区三区| 免费看亚洲片| 久久久久久久国产| 欧美一级成年大片在线观看| 亚洲在线观看免费视频| 日韩午夜电影av| 亚洲国语精品自产拍在线观看| 亚洲国产欧美日韩| 亚洲电影第1页| 亚洲国产激情| 亚洲国产精品一区二区尤物区| 在线电影国产精品| 黄色国产精品一区二区三区| 国产日产欧美a一级在线| 国产精品视频观看| 国产精品日韩欧美大师| 国产精品嫩草99a| 国产嫩草一区二区三区在线观看| 国产精品美女久久久久aⅴ国产馆| 国产精品福利在线观看| 国产精品视屏| 国模叶桐国产精品一区| 91久久精品日日躁夜夜躁国产| 日韩性生活视频| 亚洲男人的天堂在线aⅴ视频| 欧美综合二区| 嫩草国产精品入口| 亚洲人成网站色ww在线| 亚洲一区在线直播|