真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL論文怎么寫 2021中秋節(jié)要調(diào)休嗎

計(jì)算機(jī)類論文怎么寫

作為一個(gè)著重研究信息系統(tǒng)開發(fā)、應(yīng)用的專業(yè),計(jì)算機(jī)畢業(yè)論文的寫作應(yīng)該更貼合實(shí)際出來,可能有很多剛拿到題目的學(xué)生不知道改如何著手,下面我們就來了解一下計(jì)算機(jī)畢業(yè)論文怎么寫?

麻章ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!

一、計(jì)算機(jī)畢業(yè)論文的寫作方法

1、前言部分

前言部分也常用"引論"、"概論"、"問題背景"等做標(biāo)題,在這部分中,主要介紹論文的選題。

首先要闡明選題的背景和選題的意義。選題需強(qiáng)調(diào)實(shí)際背景,說明在計(jì)算機(jī)研究中或部門信息化建設(shè)、企業(yè)管理現(xiàn)代化等工作中引發(fā)該問題的原因,問題出現(xiàn)的環(huán)境和條件,解決該問題后能起什么作用。結(jié)合問題背景的闡述,要使讀者感受到此選題確有實(shí)用價(jià)值和學(xué)術(shù)價(jià)值,因而有研究和開發(fā)的必要性。

前言部分常起到畫龍點(diǎn)睛的作用。選題實(shí)際又有新意,表明作者的研究方向正確,設(shè)計(jì)開發(fā)工作有價(jià)值。對(duì)一篇論文來說,前言寫好了,就會(huì)吸引讀者,使他們對(duì)作者的選題感興趣,愿意進(jìn)一步了解作者的工作成果。

?

2、綜述部分

任何一個(gè)課題的研究或開發(fā)都是有學(xué)科基礎(chǔ)或技術(shù)基礎(chǔ)的。綜述部分主要闡述選題在相應(yīng)學(xué)科領(lǐng)域中的發(fā)展進(jìn)程和研究方向,特別是近年來的發(fā)展趨勢(shì)和最新成果。通過與中外研究成果的比較和評(píng)論,說明自己的選題是符合當(dāng)前的研究方向并有所進(jìn)展,或采用了當(dāng)前的最新技術(shù)并有所改進(jìn),目的是使讀者進(jìn)一步了解選題的意義。

綜述部分能反映出畢業(yè)設(shè)計(jì)學(xué)生多方面的能力。首先是結(jié)合課題任務(wù)獨(dú)立查閱中外文獻(xiàn)資料的能力,通過查閱文獻(xiàn)資料,收集各種信息,了解同行的研究水平,在工作和論文中有效地運(yùn)用文獻(xiàn),這不僅能避免簡(jiǎn)單的重復(fù)研究,而且也能使論文工作有一個(gè)高起點(diǎn)。

其次,還能反映出綜合分析的能力。從大量的文獻(xiàn)中找到可以借鑒和參考的信息,這不僅要有一定的專業(yè)知識(shí)水平,還要有一定的綜合能力。對(duì)同行研究成果是否能抓住要點(diǎn),優(yōu)缺點(diǎn)的評(píng)述是否符合實(shí)際,恰到好處,這和一個(gè)人的分析理解能力是有關(guān)的。

值得注意的是,要做好一篇畢業(yè)論文,必須閱讀一定量(2~3篇)的近期外文資料,這不僅反映自己的外文閱讀能力,而且有助于體現(xiàn)論文的先進(jìn)性。

3、方案論證

在明確了所要解決的問題和課題綜述后,很自然地就要提出自己解決問題的思路和方案。在寫作方法上,一是要通過比較,顯示自己方案的價(jià)值,二是讓讀者了解方案的獨(dú)到之處或有創(chuàng)新點(diǎn)的思路、算法和關(guān)鍵技術(shù)。

在與文獻(xiàn)資料中的方案進(jìn)行比較時(shí),首先要闡述自己的設(shè)計(jì)方案,說明為什么要選擇或設(shè)計(jì)這樣的方案,前面評(píng)述的優(yōu)點(diǎn)在此方案中如何體現(xiàn),不足之處又是如何得到了克服,最后完成的工作能達(dá)到什么性能水平,有什么創(chuàng)新之處(或有新意)。如果自己的題目是總方案的一部分,一定要明確說明自己承擔(dān)的部分,以及對(duì)整個(gè)任務(wù)的貢獻(xiàn)。

4、論文主體

在這部分中,要將整個(gè)研究開發(fā)工作的內(nèi)容,包括理論分析、總體設(shè)計(jì)、模塊劃分、實(shí)現(xiàn)方法等進(jìn)行詳細(xì)的論述。論文主體部分要占4/5左右。主體部分的寫法,視選題的不同可以多樣,研究型論文和應(yīng)用開發(fā)型論文的寫法就有明顯的不同。

研究型的論文,主體部分一般應(yīng)包括:理論基礎(chǔ),數(shù)學(xué)模型,算法推導(dǎo),形式化描述,求解方法,軟硬件系統(tǒng)的實(shí)現(xiàn)及調(diào)試,測(cè)試數(shù)據(jù)的分析及結(jié)論。

要強(qiáng)調(diào)的是,研究型論文絕不是從推理到推理的空洞文章。研究型論文也應(yīng)有實(shí)際背景,也應(yīng)有到企業(yè)和實(shí)際部門調(diào)研的過程,并在實(shí)際調(diào)查研究中獲取信息,發(fā)現(xiàn)問題,收集數(shù)據(jù)和資料。在研究分析的基礎(chǔ)上,提出解決實(shí)際問題的、富有創(chuàng)建性的結(jié)論。

應(yīng)用開發(fā)型的論文,主體部分應(yīng)包括:總體設(shè)計(jì),模塊劃分,算法描述,編程模型,數(shù)據(jù)結(jié)構(gòu),實(shí)現(xiàn)技術(shù),實(shí)例測(cè)試及性能分析。

以上內(nèi)容根據(jù)任務(wù)所處的階段不同,可以有所側(cè)重。在整個(gè)任務(wù)初期的論文,可側(cè)重于研究與設(shè)計(jì),在任務(wù)后期的論文可側(cè)重于實(shí)現(xiàn)與應(yīng)用。但作為一篇完整的論文應(yīng)讓讀者從課題的原理設(shè)計(jì),問題的解決方法,關(guān)鍵技術(shù)以及性能測(cè)試都有全面的了解,以便能準(zhǔn)確地評(píng)判論文的質(zhì)量。

論文主體部分的內(nèi)容一般要分成幾個(gè)章節(jié)來描述。在寫作上,除了用文字描述外,還要善于利用各種原理圖、流程圖、表格、曲線等來說明問題,一篇條理清晰,圖文并茂的論文才是一篇好的論文。

5、測(cè)試及性能分析

對(duì)理工專業(yè)的畢業(yè)設(shè)計(jì)論文,測(cè)試數(shù)據(jù)是性能評(píng)價(jià)的基礎(chǔ),必須真實(shí)可靠。通過測(cè)試數(shù)據(jù),論文工作的成效可一目了然。根據(jù)課題的要求,可以在實(shí)驗(yàn)室環(huán)境下測(cè)試,也可以在工作現(xiàn)場(chǎng)測(cè)試。

在論文中,要將測(cè)試時(shí)的環(huán)境和條件列出,因?yàn)槿魏螠y(cè)試數(shù)據(jù)都與測(cè)試環(huán)境和條件相關(guān),不說明測(cè)試條件的數(shù)據(jù)是不可比的,因此也是無意義的。

測(cè)試一般包括功能測(cè)試和性能測(cè)試。功能測(cè)試是將課題完成的計(jì)算機(jī)軟硬件系統(tǒng)(子系統(tǒng))或應(yīng)用系統(tǒng)所要求達(dá)到的功能逐一進(jìn)行測(cè)試。性能測(cè)試一般是在系統(tǒng)(子系統(tǒng))的運(yùn)行狀態(tài)下,記錄實(shí)例運(yùn)行的數(shù)據(jù),然后,歸納和計(jì)算這些數(shù)據(jù),以此來分析系統(tǒng)運(yùn)行的性能。

測(cè)試實(shí)例可以自己設(shè)計(jì)編寫,也可以選擇學(xué)科領(lǐng)域內(nèi)公認(rèn)的、有一定權(quán)威性的測(cè)試實(shí)例或測(cè)試集。原則是通過所選擇(設(shè)計(jì))的實(shí)例的運(yùn)行,既能準(zhǔn)確反映系統(tǒng)運(yùn)行的功能和性能,與同類系統(tǒng)又有可比性。只有這樣,論文最后為自己工作所做的結(jié)論才有說服力。

6、結(jié)束語(yǔ)

這一節(jié)篇幅不大,首先對(duì)整個(gè)論文工作做一個(gè)簡(jiǎn)單小結(jié),然后將自己在研究開發(fā)工作中所做的貢獻(xiàn),或獨(dú)立研究的成果列舉出來,再對(duì)自己工作的進(jìn)展、水平做一個(gè)實(shí)事求是的評(píng)論。但在用"首次提出"、"重大突破"、"重要價(jià)值"等自我評(píng)語(yǔ)時(shí)要慎重。

7、后記

在后記中,主要表達(dá)對(duì)導(dǎo)師和其他有關(guān)教師和同學(xué)的感謝之意。對(duì)此,仍要實(shí)事求是,過分的頌揚(yáng)反而會(huì)帶來消極影響。這一節(jié)也可用"致謝"做標(biāo)題。

8、參考文獻(xiàn)

中外文的參考文獻(xiàn)應(yīng)按照規(guī)范列舉在論文最后。這一部分的編寫反映作者的學(xué)術(shù)作風(fēng)。編寫參考文獻(xiàn)要注意:(1)要嚴(yán)格按照規(guī)范編寫,特別是外文文獻(xiàn),不要漏寫、錯(cuò)寫;(2)論文內(nèi)容和參考文獻(xiàn)要前后對(duì)應(yīng),正文中凡引用參考文獻(xiàn)的地方應(yīng)加注;(3)列出的文獻(xiàn)資料應(yīng)與論文課題相關(guān),無關(guān)的文獻(xiàn)只會(huì)使讀者感到作者的研究目標(biāo)很分散;(4)選擇的參考文獻(xiàn)應(yīng)主要是近期的。

二、計(jì)算機(jī)寫作注意事項(xiàng)

1、設(shè)計(jì)(論文)題目:按照小題目。封面XXXXX學(xué)院畢業(yè)設(shè)計(jì)(論文)、 屆 分院(系)

2、摘要:不要主語(yǔ),英文中無法表達(dá)時(shí)可用被動(dòng)語(yǔ)態(tài)

3、關(guān)鍵詞:體現(xiàn)設(shè)計(jì)(論文)主要工作的詞語(yǔ)

4、目錄:自動(dòng)生成,1.1.1的格式,最多到1.1.1.1 5、正文中文獻(xiàn)引用要客觀,別人的成果要說明,不要據(jù)為己有;自己的成果要突出。不清楚的圖必須修改(可用word畫或者AutoCAD畫),表格盡量采用三線表

6、參考文獻(xiàn):至少要有兩篇英文文獻(xiàn)

7、致謝(不是致辭)

8、附錄(若多于一個(gè)附錄,可用附錄一、附錄二,……)

9、各部分格式要求,嚴(yán)格按照畢業(yè)設(shè)計(jì)手冊(cè)執(zhí)行

三、計(jì)算機(jī)論文編輯技巧

1、文檔結(jié)構(gòu)圖的妙用 格式修改時(shí)可先將全文設(shè)置為正文格式(新羅馬與宋體的博弈),然后將三級(jí)標(biāo)題以上標(biāo)題按照三級(jí)標(biāo)題提出來,再將二級(jí)標(biāo)題以上標(biāo)題按照二級(jí)標(biāo)題提出來,最后將一級(jí)標(biāo)題提出來。提出標(biāo)題時(shí)注意使用大綱級(jí)別。 提出大綱級(jí)別后,可用文檔結(jié)構(gòu)圖輕松導(dǎo)航文檔。還可自動(dòng)生成目錄(插入-引用-索引和目錄-目錄)。

2、圖的裁剪與組合(建議采用浮于文字上方的方式)、文本框的妙用、公式的編輯(變量用斜體、下標(biāo)用的i、j、k用斜體,其余用正體。公式中出現(xiàn)漢字怎么辦?用拼音加加輸入法輸入漢字)

3、表格的編輯

4、上下標(biāo)的使用(自定義word菜單)

5、分節(jié)符的使用

6、目錄自動(dòng)生成(頁(yè)碼的問題),目錄可單獨(dú)取文件名(寫字板的運(yùn)用),也可放到正文前面

7、樣式與格式的自動(dòng)更新功能

8、頁(yè)眉設(shè)置(去掉橫線)

9、文檔的備份(防止病毒感染、U盤丟失、計(jì)算機(jī)故障)

選擇恰當(dāng)?shù)臄?shù)據(jù)庫(kù)論文寫作中有哪些方面的作用

數(shù)據(jù)庫(kù)設(shè)計(jì)方法、規(guī)范與技巧

一、數(shù)據(jù)庫(kù)設(shè)計(jì)過程

數(shù)據(jù)庫(kù)技術(shù)是信息資源管理最有效的手段。數(shù)據(jù)庫(kù)設(shè)計(jì)是指對(duì)于一個(gè)給定的應(yīng)用環(huán)境,構(gòu)造最優(yōu)的數(shù)據(jù)庫(kù)模式,建立數(shù)據(jù)庫(kù)及其應(yīng)用系統(tǒng),有效存儲(chǔ)數(shù)據(jù),滿足用戶信息要求和處理要求。

數(shù)據(jù)庫(kù)設(shè)計(jì)中需求分析階段綜合各個(gè)用戶的應(yīng)用需求(現(xiàn)實(shí)世界的需求),在概念設(shè)計(jì)階段形成獨(dú)立于機(jī)器特點(diǎn)、獨(dú)立于各個(gè)DBMS產(chǎn)品的概念模式(信息世界模型),用E-R圖來描述。在邏輯設(shè)計(jì)階段將E-R圖轉(zhuǎn)換成具體的數(shù)據(jù)庫(kù)產(chǎn)品支持的數(shù)據(jù)模型如關(guān)系模型,形成數(shù)據(jù)庫(kù)邏輯模式。然后根據(jù)用戶處理的要求,安全性的考慮,在基本表的基礎(chǔ)上再建立必要的視圖(VIEW)形成數(shù)據(jù)的外模式。在物理設(shè)計(jì)階段根據(jù)DBMS特點(diǎn)和處理的需要,進(jìn)行物理存儲(chǔ)安排,設(shè)計(jì)索引,形成數(shù)據(jù)庫(kù)內(nèi)模式。

1. 需求分析階段

需求收集和分析,結(jié)果得到數(shù)據(jù)字典描述的數(shù)據(jù)需求(和數(shù)據(jù)流圖描述的處理需求)。

需求分析的重點(diǎn)是調(diào)查、收集與分析用戶在數(shù)據(jù)管理中的信息要求、處理要求、安全性與完整性要求。

需求分析的方法:調(diào)查組織機(jī)構(gòu)情況、調(diào)查各部門的業(yè)務(wù)活動(dòng)情況、協(xié)助用戶明確對(duì)新系統(tǒng)的各種要求、確定新系統(tǒng)的邊界。

常用的調(diào)查方法有: 跟班作業(yè)、開調(diào)查會(huì)、請(qǐng)專人介紹、詢問、設(shè)計(jì)調(diào)查表請(qǐng)用戶填寫、查閱記錄。

分析和表達(dá)用戶需求的方法主要包括自頂向下和自底向上兩類方法。自頂向下的結(jié)構(gòu)化分析方法(Structured Analysis,簡(jiǎn)稱SA方法)從最上層的系統(tǒng)組織機(jī)構(gòu)入手,采用逐層分解的方式分析系統(tǒng),并把每一層用數(shù)據(jù)流圖和數(shù)據(jù)字典描述。

數(shù)據(jù)流圖表達(dá)了數(shù)據(jù)和處理過程的關(guān)系。系統(tǒng)中的數(shù)據(jù)則借助數(shù)據(jù)字典(Data Dictionary,簡(jiǎn)稱DD)來描述。

數(shù)據(jù)字典是各類數(shù)據(jù)描述的集合,它是關(guān)于數(shù)據(jù)庫(kù)中數(shù)據(jù)的描述,即元數(shù)據(jù),而不是數(shù)據(jù)本身。數(shù)據(jù)字典通常包括數(shù)據(jù)項(xiàng)、數(shù)據(jù)結(jié)構(gòu)、數(shù)據(jù)流、數(shù)據(jù)存儲(chǔ)和處理過程五個(gè)部分(至少應(yīng)該包含每個(gè)字段的數(shù)據(jù)類型和在每個(gè)表內(nèi)的主外鍵)。

數(shù)據(jù)項(xiàng)描述={數(shù)據(jù)項(xiàng)名,數(shù)據(jù)項(xiàng)含義說明,別名,數(shù)據(jù)類型,長(zhǎng)度,

取值范圍,取值含義,與其他數(shù)據(jù)項(xiàng)的邏輯關(guān)系}

數(shù)據(jù)結(jié)構(gòu)描述={數(shù)據(jù)結(jié)構(gòu)名,含義說明,組成:{數(shù)據(jù)項(xiàng)或數(shù)據(jù)結(jié)構(gòu)}}

數(shù)據(jù)流描述={數(shù)據(jù)流名,說明,數(shù)據(jù)流來源,數(shù)據(jù)流去向,

組成:{數(shù)據(jù)結(jié)構(gòu)},平均流量,高峰期流量}

數(shù)據(jù)存儲(chǔ)描述={數(shù)據(jù)存儲(chǔ)名,說明,編號(hào),流入的數(shù)據(jù)流,流出的數(shù)據(jù)流,

組成:{數(shù)據(jù)結(jié)構(gòu)},數(shù)據(jù)量,存取方式}

處理過程描述={處理過程名,說明,輸入:{數(shù)據(jù)流},輸出:{數(shù)據(jù)流},

處理:{簡(jiǎn)要說明}}

2. 概念結(jié)構(gòu)設(shè)計(jì)階段

通過對(duì)用戶需求進(jìn)行綜合、歸納與抽象,形成一個(gè)獨(dú)立于具體DBMS的概念模型,可以用E-R圖表示。

概念模型用于信息世界的建模。概念模型不依賴于某一個(gè)DBMS支持的數(shù)據(jù)模型。概念模型可以轉(zhuǎn)換為計(jì)算機(jī)上某一DBMS支持的特定數(shù)據(jù)模型。

概念模型特點(diǎn):

(1) 具有較強(qiáng)的語(yǔ)義表達(dá)能力,能夠方便、直接地表達(dá)應(yīng)用中的各種語(yǔ)義知識(shí)。

(2) 應(yīng)該簡(jiǎn)單、清晰、易于用戶理解,是用戶與數(shù)據(jù)庫(kù)設(shè)計(jì)人員之間進(jìn)行交流的語(yǔ)言。

概念模型設(shè)計(jì)的一種常用方法為IDEF1X方法,它就是把實(shí)體-聯(lián)系方法應(yīng)用到語(yǔ)義數(shù)據(jù)模型中的一種語(yǔ)義模型化技術(shù),用于建立系統(tǒng)信息模型。

使用IDEF1X方法創(chuàng)建E-R模型的步驟如下所示:

2.1 第零步——初始化工程

這個(gè)階段的任務(wù)是從目的描述和范圍描述開始,確定建模目標(biāo),開發(fā)建模計(jì)劃,組織建模隊(duì)伍,收集源材料,制定約束和規(guī)范。收集源材料是這階段的重點(diǎn)。通過調(diào)查和觀察結(jié)果,業(yè)務(wù)流程,原有系統(tǒng)的輸入輸出,各種報(bào)表,收集原始數(shù)據(jù),形成了基本數(shù)據(jù)資料表。

2.2 第一步——定義實(shí)體

實(shí)體集成員都有一個(gè)共同的特征和屬性集,可以從收集的源材料——基本數(shù)據(jù)資料表中直接或間接標(biāo)識(shí)出大部分實(shí)體。根據(jù)源材料名字表中表示物的術(shù)語(yǔ)以及具有“代碼”結(jié)尾的術(shù)語(yǔ),如客戶代碼、代理商代碼、產(chǎn)品代碼等將其名詞部分代表的實(shí)體標(biāo)識(shí)出來,從而初步找出潛在的實(shí)體,形成初步實(shí)體表。

2.3 第二步——定義聯(lián)系

IDEF1X模型中只允許二元聯(lián)系,n元聯(lián)系必須定義為n個(gè)二元聯(lián)系。根據(jù)實(shí)際的業(yè)務(wù)需求和規(guī)則,使用實(shí)體聯(lián)系矩陣來標(biāo)識(shí)實(shí)體間的二元關(guān)系,然后根據(jù)實(shí)際情況確定出連接關(guān)系的勢(shì)、關(guān)系名和說明,確定關(guān)系類型,是標(biāo)識(shí)關(guān)系、非標(biāo)識(shí)關(guān)系(強(qiáng)制的或可選的)還是非確定關(guān)系、分類關(guān)系。如果子實(shí)體的每個(gè)實(shí)例都需要通過和父實(shí)體的關(guān)系來標(biāo)識(shí),則為標(biāo)識(shí)關(guān)系,否則為非標(biāo)識(shí)關(guān)系。非標(biāo)識(shí)關(guān)系中,如果每個(gè)子實(shí)體的實(shí)例都與而且只與一個(gè)父實(shí)體關(guān)聯(lián),則為強(qiáng)制的,否則為非強(qiáng)制的。如果父實(shí)體與子實(shí)體代表的是同一現(xiàn)實(shí)對(duì)象,那么它們?yōu)榉诸愱P(guān)系。

2.4 第三步——定義碼

通過引入交叉實(shí)體除去上一階段產(chǎn)生的非確定關(guān)系,然后從非交叉實(shí)體和獨(dú)立實(shí)體開始標(biāo)識(shí)侯選碼屬性,以便唯一識(shí)別每個(gè)實(shí)體的實(shí)例,再?gòu)暮钸x碼中確定主碼。為了確定主碼和關(guān)系的有效性,通過非空規(guī)則和非多值規(guī)則來保證,即一個(gè)實(shí)體實(shí)例的一個(gè)屬性不能是空值,也不能在同一個(gè)時(shí)刻有一個(gè)以上的值。找出誤認(rèn)的確定關(guān)系,將實(shí)體進(jìn)一步分解,最后構(gòu)造出IDEF1X模型的鍵基視圖(KB圖)。

2.5 第四步——定義屬性

從源數(shù)據(jù)表中抽取說明性的名詞開發(fā)出屬性表,確定屬性的所有者。定義非主碼屬性,檢查屬性的非空及非多值規(guī)則。此外,還要檢查完全依賴函數(shù)規(guī)則和非傳遞依賴規(guī)則,保證一個(gè)非主碼屬性必須依賴于主碼、整個(gè)主碼、僅僅是主碼。以此得到了至少符合關(guān)系理論第三范式的改進(jìn)的IDEF1X模型的全屬性視圖。

2.6 第五步——定義其他對(duì)象和規(guī)則

定義屬性的數(shù)據(jù)類型、長(zhǎng)度、精度、非空、缺省值、約束規(guī)則等。定義觸發(fā)器、存儲(chǔ)過程、視圖、角色、同義詞、序列等對(duì)象信息。

3. 邏輯結(jié)構(gòu)設(shè)計(jì)階段

將概念結(jié)構(gòu)轉(zhuǎn)換為某個(gè)DBMS所支持的數(shù)據(jù)模型(例如關(guān)系模型),并對(duì)其進(jìn)行優(yōu)化。設(shè)計(jì)邏輯結(jié)構(gòu)應(yīng)該選擇最適于描述與表達(dá)相應(yīng)概念結(jié)構(gòu)的數(shù)據(jù)模型,然后選擇最合適的DBMS。

將E-R圖轉(zhuǎn)換為關(guān)系模型實(shí)際上就是要將實(shí)體、實(shí)體的屬性和實(shí)體之間的聯(lián)系轉(zhuǎn)化為關(guān)系模式,這種轉(zhuǎn)換一般遵循如下原則:

1)一個(gè)實(shí)體型轉(zhuǎn)換為一個(gè)關(guān)系模式。實(shí)體的屬性就是關(guān)系的屬性。實(shí)體的碼就是關(guān)系的碼。

2)一個(gè)m:n聯(lián)系轉(zhuǎn)換為一個(gè)關(guān)系模式。與該聯(lián)系相連的各實(shí)體的碼以及聯(lián)系本身的屬性均轉(zhuǎn)換為關(guān)系的屬性。而關(guān)系的碼為各實(shí)體碼的組合。

3)一個(gè)1:n聯(lián)系可以轉(zhuǎn)換為一個(gè)獨(dú)立的關(guān)系模式,也可以與n端對(duì)應(yīng)的關(guān)系模式合并。如果轉(zhuǎn)換為一個(gè)獨(dú)立的關(guān)系模式,則與該聯(lián)系相連的各實(shí)體的碼以及聯(lián)系本身的屬性均轉(zhuǎn)換為關(guān)系的屬性,而關(guān)系的碼為n端實(shí)體的碼。

4)一個(gè)1:1聯(lián)系可以轉(zhuǎn)換為一個(gè)獨(dú)立的關(guān)系模式,也可以與任意一端對(duì)應(yīng)的關(guān)系模式合并。

5)三個(gè)或三個(gè)以上實(shí)體間的一個(gè)多元聯(lián)系轉(zhuǎn)換為一個(gè)關(guān)系模式。與該多元聯(lián)系相連的各實(shí)體的碼以及聯(lián)系本身的屬性均轉(zhuǎn)換為關(guān)系的屬性。而關(guān)系的碼為各實(shí)體碼的組合。

6)同一實(shí)體集的實(shí)體間的聯(lián)系,即自聯(lián)系,也可按上述1:1、1:n和m:n三種情況分別處理。

7)具有相同碼的關(guān)系模式可合并。

為了進(jìn)一步提高數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)的性能,通常以規(guī)范化理論為指導(dǎo),還應(yīng)該適當(dāng)?shù)匦薷?、調(diào)整數(shù)據(jù)模型的結(jié)構(gòu),這就是數(shù)據(jù)模型的優(yōu)化。確定數(shù)據(jù)依賴。消除冗余的聯(lián)系。確定各關(guān)系模式分別屬于第幾范式。確定是否要對(duì)它們進(jìn)行合并或分解。一般來說將關(guān)系分解為3NF的標(biāo)準(zhǔn),即:

表內(nèi)的每一個(gè)值都只能被表達(dá)一次。

??表內(nèi)的每一行都應(yīng)該被唯一的標(biāo)識(shí)(有唯一鍵)。

表內(nèi)不應(yīng)該存儲(chǔ)依賴于其他鍵的非鍵信息。

4. 數(shù)據(jù)庫(kù)物理設(shè)計(jì)階段

為邏輯數(shù)據(jù)模型選取一個(gè)最適合應(yīng)用環(huán)境的物理結(jié)構(gòu)(包括存儲(chǔ)結(jié)構(gòu)和存取方法)。根據(jù)DBMS特點(diǎn)和處理的需要,進(jìn)行物理存儲(chǔ)安排,設(shè)計(jì)索引,形成數(shù)據(jù)庫(kù)內(nèi)模式。

5. 數(shù)據(jù)庫(kù)實(shí)施階段

運(yùn)用DBMS提供的數(shù)據(jù)語(yǔ)言(例如SQL)及其宿主語(yǔ)言(例如C),根據(jù)邏輯設(shè)計(jì)和物理設(shè)計(jì)的結(jié)果建立數(shù)據(jù)庫(kù),編制與調(diào)試應(yīng)用程序,組織數(shù)據(jù)入庫(kù),并進(jìn)行試運(yùn)行。 數(shù)據(jù)庫(kù)實(shí)施主要包括以下工作:用DDL定義數(shù)據(jù)庫(kù)結(jié)構(gòu)、組織數(shù)據(jù)入庫(kù) 、編制與調(diào)試應(yīng)用程序、數(shù)據(jù)庫(kù)試運(yùn)行 6. 數(shù)據(jù)庫(kù)運(yùn)行和維護(hù)階段

數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)經(jīng)過試運(yùn)行后即可投入正式運(yùn)行。在數(shù)據(jù)庫(kù)系統(tǒng)運(yùn)行過程中必須不斷地對(duì)其進(jìn)行評(píng)價(jià)、調(diào)整與修改。包括:數(shù)據(jù)庫(kù)的轉(zhuǎn)儲(chǔ)和恢復(fù)、數(shù)據(jù)庫(kù)的安全性、完整性控制、數(shù)據(jù)庫(kù)性能的監(jiān)督、分析和改進(jìn)、數(shù)據(jù)庫(kù)的重組織和重構(gòu)造。

建模工具的使用

為加快數(shù)據(jù)庫(kù)設(shè)計(jì)速度,目前有很多數(shù)據(jù)庫(kù)輔助工具(CASE工具),如Rational公司的Rational Rose,CA公司的Erwin和Bpwin,Sybase公司的PowerDesigner以及Oracle公司的Oracle Designer等。

ERwin主要用來建立數(shù)據(jù)庫(kù)的概念模型和物理模型。它能用圖形化的方式,描述出實(shí)體、聯(lián)系及實(shí)體的屬性。ERwin支持IDEF1X方法。通過使用ERwin建模工具自動(dòng)生成、更改和分析IDEF1X模型,不僅能得到優(yōu)秀的業(yè)務(wù)功能和數(shù)據(jù)需求模型,而且可以實(shí)現(xiàn)從IDEF1X模型到數(shù)據(jù)庫(kù)物理設(shè)計(jì)的轉(zhuǎn)變。ERwin工具繪制的模型對(duì)應(yīng)于邏輯模型和物理模型兩種。在邏輯模型中,IDEF1X工具箱可以方便地用圖形化的方式構(gòu)建和繪制實(shí)體聯(lián)系及實(shí)體的屬性。在物理模型中,ERwin可以定義對(duì)應(yīng)的表、列,并可針對(duì)各種數(shù)據(jù)庫(kù)管理系統(tǒng)自動(dòng)轉(zhuǎn)換為適當(dāng)?shù)念愋汀?/p>

設(shè)計(jì)人員可根據(jù)需要選用相應(yīng)的數(shù)據(jù)庫(kù)設(shè)計(jì)建模工具。例如需求分析完成之后,設(shè)計(jì)人員可以使用Erwin畫ER圖,將ER圖轉(zhuǎn)換為關(guān)系數(shù)據(jù)模型,生成數(shù)據(jù)庫(kù)結(jié)構(gòu);畫數(shù)據(jù)流圖,生成應(yīng)用程序。

二、數(shù)據(jù)庫(kù)設(shè)計(jì)技巧

1. 設(shè)計(jì)數(shù)據(jù)庫(kù)之前(需求分析階段)

1) 理解客戶需求,詢問用戶如何看待未來需求變化。讓客戶解釋其需求,而且隨著開發(fā)的繼續(xù),還要經(jīng)常詢問客戶保證其需求仍然在開發(fā)的目的之中。

2) 了解企業(yè)業(yè)務(wù)可以在以后的開發(fā)階段節(jié)約大量的時(shí)間。

3) 重視輸入輸出。

在定義數(shù)據(jù)庫(kù)表和字段需求(輸入)時(shí),首先應(yīng)檢查現(xiàn)有的或者已經(jīng)設(shè)計(jì)出的報(bào)表、查詢和視圖(輸出)以決定為了支持這些輸出哪些是必要的表和字段。

舉例:假如客戶需要一個(gè)報(bào)表按照郵政編碼排序、分段和求和,你要保證其中包括了單獨(dú)的郵政編碼字段而不要把郵政編碼糅進(jìn)地址字段里。

4) 創(chuàng)建數(shù)據(jù)字典和ER 圖表

ER 圖表和數(shù)據(jù)字典可以讓任何了解數(shù)據(jù)庫(kù)的人都明確如何從數(shù)據(jù)庫(kù)中獲得數(shù)據(jù)。ER圖對(duì)表明表之間關(guān)系很有用,而數(shù)據(jù)字典則說明了每個(gè)字段的用途以及任何可能存在的別名。對(duì)SQL 表達(dá)式的文檔化來說這是完全必要的。

5) 定義標(biāo)準(zhǔn)的對(duì)象命名規(guī)范

數(shù)據(jù)庫(kù)各種對(duì)象的命名必須規(guī)范。

2. 表和字段的設(shè)計(jì)(數(shù)據(jù)庫(kù)邏輯設(shè)計(jì))

表設(shè)計(jì)原則

1) 標(biāo)準(zhǔn)化和規(guī)范化

數(shù)據(jù)的標(biāo)準(zhǔn)化有助于消除數(shù)據(jù)庫(kù)中的數(shù)據(jù)冗余。標(biāo)準(zhǔn)化有好幾種形式,但Third Normal Form(3NF)通常被認(rèn)為在性能、擴(kuò)展性和數(shù)據(jù)完整性方面達(dá)到了最好平衡。簡(jiǎn)單來說,遵守3NF 標(biāo)準(zhǔn)的數(shù)據(jù)庫(kù)的表設(shè)計(jì)原則是:“One Fact in One Place”即某個(gè)表只包括其本身基本的屬性,當(dāng)不是它們本身所具有的屬性時(shí)需進(jìn)行分解。表之間的關(guān)系通過外鍵相連接。它具有以下特點(diǎn):有一組表專門存放通過鍵連接起來的關(guān)聯(lián)數(shù)據(jù)。

舉例:某個(gè)存放客戶及其有關(guān)定單的3NF 數(shù)據(jù)庫(kù)就可能有兩個(gè)表:Customer 和Order。Order 表不包含定單關(guān)聯(lián)客戶的任何信息,但表內(nèi)會(huì)存放一個(gè)鍵值,該鍵指向Customer 表里包含該客戶信息的那一行。

事實(shí)上,為了效率的緣故,對(duì)表不進(jìn)行標(biāo)準(zhǔn)化有時(shí)也是必要的。

2) 數(shù)據(jù)驅(qū)動(dòng)

采用數(shù)據(jù)驅(qū)動(dòng)而非硬編碼的方式,許多策略變更和維護(hù)都會(huì)方便得多,大大增強(qiáng)系統(tǒng)的靈活性和擴(kuò)展性。

舉例,假如用戶界面要訪問外部數(shù)據(jù)源(文件、XML 文檔、其他數(shù)據(jù)庫(kù)等),不妨把相應(yīng)的連接和路徑信息存儲(chǔ)在用戶界面支持表里。還有,如果用戶界面執(zhí)行工作流之類的任務(wù)(發(fā)送郵件、打印信箋、修改記錄狀態(tài)等),那么產(chǎn)生工作流的數(shù)據(jù)也可以存放在數(shù)據(jù)庫(kù)里。角色權(quán)限管理也可以通過數(shù)據(jù)驅(qū)動(dòng)來完成。事實(shí)上,如果過程是數(shù)據(jù)驅(qū)動(dòng)的,你就可以把相當(dāng)大的責(zé)任推給用戶,由用戶來維護(hù)自己的工作流過程。

3) 考慮各種變化

在設(shè)計(jì)數(shù)據(jù)庫(kù)的時(shí)候考慮到哪些數(shù)據(jù)字段將來可能會(huì)發(fā)生變更。 舉例,姓氏就是如此(注意是西方人的姓氏,比如女性結(jié)婚后從夫姓等)。所以,在建立系統(tǒng)存儲(chǔ)客戶信息時(shí),在單獨(dú)的一個(gè)數(shù)據(jù)表里存儲(chǔ)姓氏字段,而且還附加起始日和終止日等字段,這樣就可以跟蹤這一數(shù)據(jù)條目的變化。

字段設(shè)計(jì)原則

4) 每個(gè)表中都應(yīng)該添加的3 個(gè)有用的字段

??dRecordCreationDate,在VB 下默認(rèn)是Now(),而在SQL Server 下默認(rèn)為GETDATE()

??sRecordCreator,在SQL Server 下默認(rèn)為NOT NULL DEFAULT USER

??nRecordVersion,記錄的版本標(biāo)記;有助于準(zhǔn)確說明記錄中出現(xiàn)null 數(shù)據(jù)或者丟失數(shù)據(jù)的原因

5) 對(duì)地址和電話采用多個(gè)字段

描述街道地址就短短一行記錄是不夠的。Address_Line1、Address_Line2 和Address_Line3 可以提供更大的靈活性。還有,電話號(hào)碼和郵件地址最好擁有自己的數(shù)據(jù)表,其間具有自身的類型和標(biāo)記類別。

6) 使用角色實(shí)體定義屬于某類別的列

在需要對(duì)屬于特定類別或者具有特定角色的事物做定義時(shí),可以用角色實(shí)體來創(chuàng)建特定的時(shí)間關(guān)聯(lián)關(guān)系,從而可以實(shí)現(xiàn)自我文檔化。

舉例:用PERSON 實(shí)體和PERSON_TYPE 實(shí)體來描述人員。比方說,當(dāng)John Smith, Engineer 提升為John Smith, Director 乃至最后爬到John Smith, CIO 的高位,而所有你要做的不過是改變兩個(gè)表PERSON 和PERSON_TYPE 之間關(guān)系的鍵值,同時(shí)增加一個(gè)日期/時(shí)間字段來知道變化是何時(shí)發(fā)生的。這樣,你的PERSON_TYPE 表就包含了所有PERSON 的可能類型,比如Associate、Engineer、Director、CIO 或者CEO 等。還有個(gè)替代辦法就是改變PERSON 記錄來反映新頭銜的變化,不過這樣一來在時(shí)間上無法跟蹤個(gè)人所處位置的具體時(shí)間。

7) 選擇數(shù)字類型和文本類型盡量充足

在SQL 中使用smallint 和tinyint 類型要特別小心。比如,假如想看看月銷售總額,總額字段類型是smallint,那么,如果總額超過了$32,767 就不能進(jìn)行計(jì)算操作了。

而ID 類型的文本字段,比如客戶ID 或定單號(hào)等等都應(yīng)該設(shè)置得比一般想象更大。假設(shè)客戶ID 為10 位數(shù)長(zhǎng)。那你應(yīng)該把數(shù)據(jù)庫(kù)表字段的長(zhǎng)度設(shè)為12 或者13 個(gè)字符長(zhǎng)。但這額外占據(jù)的空間卻無需將來重構(gòu)整個(gè)數(shù)據(jù)庫(kù)就可以實(shí)現(xiàn)數(shù)據(jù)庫(kù)規(guī)模的增長(zhǎng)了。

8) 增加刪除標(biāo)記字段

在表中包含一個(gè)“刪除標(biāo)記”字段,這樣就可以把行標(biāo)記為刪除。在關(guān)系數(shù)據(jù)庫(kù)里不要單獨(dú)刪除某一行;最好采用清除數(shù)據(jù)程序而且要仔細(xì)維護(hù)索引整體性。

3. 選擇鍵和索引(數(shù)據(jù)庫(kù)邏輯設(shè)計(jì))

鍵選擇原則:

1) 鍵設(shè)計(jì)4 原則

??為關(guān)聯(lián)字段創(chuàng)建外鍵。

??所有的鍵都必須唯一。

??避免使用復(fù)合鍵。

??外鍵總是關(guān)聯(lián)唯一的鍵字段。

2) 使用系統(tǒng)生成的主鍵

設(shè)計(jì)數(shù)據(jù)庫(kù)的時(shí)候采用系統(tǒng)生成的鍵作為主鍵,那么實(shí)際控制了數(shù)據(jù)庫(kù)的索引完整性。這樣,數(shù)據(jù)庫(kù)和非人工機(jī)制就有效地控制了對(duì)存儲(chǔ)數(shù)據(jù)中每一行的訪問。采用系統(tǒng)生成鍵作為主鍵還有一個(gè)優(yōu)點(diǎn):當(dāng)擁有一致的鍵結(jié)構(gòu)時(shí),找到邏輯缺陷很容易。

3) 不要用用戶的鍵(不讓主鍵具有可更新性)

在確定采用什么字段作為表的鍵的時(shí)候,可一定要小心用戶將要編輯的字段。通常的情況下不要選擇用戶可編輯的字段作為鍵。

4) 可選鍵有時(shí)可做主鍵

把可選鍵進(jìn)一步用做主鍵,可以擁有建立強(qiáng)大索引的能力。

索引使用原則:

索引是從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù)的最高效方式之一。95%的數(shù)據(jù)庫(kù)性能問題都可以采用索引技術(shù)得到解決。

1) 邏輯主鍵使用唯一的成組索引,對(duì)系統(tǒng)鍵(作為存儲(chǔ)過程)采用唯一的非成組索引,對(duì)任何外鍵列采用非成組索引??紤]數(shù)據(jù)庫(kù)的空間有多大,表如何進(jìn)行訪問,還有這些訪問是否主要用作讀寫。

2) 大多數(shù)數(shù)據(jù)庫(kù)都索引自動(dòng)創(chuàng)建的主鍵字段,但是可別忘了索引外鍵,它們也是經(jīng)常使用的鍵,比如運(yùn)行查詢顯示主表和所有關(guān)聯(lián)表的某條記錄就用得上。

3) 不要索引memo/note 字段,不要索引大型字段(有很多字符),這樣作會(huì)讓索引占用太多的存儲(chǔ)空間。

4) 不要索引常用的小型表

不要為小型數(shù)據(jù)表設(shè)置任何鍵,假如它們經(jīng)常有插入和刪除操作就更別這樣作了。對(duì)這些插入和刪除操作的索引維護(hù)可能比掃描表空間消耗更多的時(shí)間。

4. 數(shù)據(jù)完整性設(shè)計(jì)(數(shù)據(jù)庫(kù)邏輯設(shè)計(jì))

1) 完整性實(shí)現(xiàn)機(jī)制:

實(shí)體完整性:主鍵

參照完整性:

父表中刪除數(shù)據(jù):級(jí)聯(lián)刪除;受限刪除;置空值

父表中插入數(shù)據(jù):受限插入;遞歸插入

父表中更新數(shù)據(jù):級(jí)聯(lián)更新;受限更新;置空值

DBMS對(duì)參照完整性可以有兩種方法實(shí)現(xiàn):外鍵實(shí)現(xiàn)機(jī)制(約束規(guī)則)和觸發(fā)器實(shí)現(xiàn)機(jī)制

用戶定義完整性:

NOT NULL;CHECK;觸發(fā)器

2) 用約束而非商務(wù)規(guī)則強(qiáng)制數(shù)據(jù)完整性

采用數(shù)據(jù)庫(kù)系統(tǒng)實(shí)現(xiàn)數(shù)據(jù)的完整性。這不但包括通過標(biāo)準(zhǔn)化實(shí)現(xiàn)的完整性而且還包括數(shù)據(jù)的功能性。在寫數(shù)據(jù)的時(shí)候還可以增加觸發(fā)器來保證數(shù)據(jù)的正確性。不要依賴于商務(wù)層保證數(shù)據(jù)完整性;它不能保證表之間(外鍵)的完整性所以不能強(qiáng)加于其他完整性規(guī)則之上。

3) 強(qiáng)制指示完整性

在有害數(shù)據(jù)進(jìn)入數(shù)據(jù)庫(kù)之前將其剔除。激活數(shù)據(jù)庫(kù)系統(tǒng)的指示完整性特性。這樣可以保持?jǐn)?shù)據(jù)的清潔而能迫使開發(fā)人員投入更多的時(shí)間處理錯(cuò)誤條件。

4) 使用查找控制數(shù)據(jù)完整性

控制數(shù)據(jù)完整性的最佳方式就是限制用戶的選擇。只要有可能都應(yīng)該提供給用戶一個(gè)清晰的價(jià)值列表供其選擇。這樣將減少鍵入代碼的錯(cuò)誤和誤解同時(shí)提供數(shù)據(jù)的一致性。某些公共數(shù)據(jù)特別適合查找:國(guó)家代碼、狀態(tài)代碼等。

5) 采用視圖

為了在數(shù)據(jù)庫(kù)和應(yīng)用程序代碼之間提供另一層抽象,可以為應(yīng)用程序建立專門的視圖而不必非要應(yīng)用程序直接訪問數(shù)據(jù)表。這樣做還等于在處理數(shù)據(jù)庫(kù)變更時(shí)給你提供了更多的自由。

5. 其他設(shè)計(jì)技巧

1) 避免使用觸發(fā)器

觸發(fā)器的功能通??梢杂闷渌绞綄?shí)現(xiàn)。在調(diào)試程序時(shí)觸發(fā)器可能成為干擾。假如你確實(shí)需要采用觸發(fā)器,你最好集中對(duì)它文檔化。

2) 使用常用英語(yǔ)(或者其他任何語(yǔ)言)而不要使用編碼

在創(chuàng)建下拉菜單、列表、報(bào)表時(shí)最好按照英語(yǔ)名排序。假如需要編碼,可以在編碼旁附上用戶知道的英語(yǔ)。

3) 保存常用信息

讓一個(gè)表專門存放一般數(shù)據(jù)庫(kù)信息非常有用。在這個(gè)表里存放數(shù)據(jù)庫(kù)當(dāng)前版本、最近檢查/修復(fù)(對(duì)Access)、關(guān)聯(lián)設(shè)計(jì)文檔的名稱、客戶等信息。這樣可以實(shí)現(xiàn)一種簡(jiǎn)單機(jī)制跟蹤數(shù)據(jù)庫(kù),當(dāng)客戶抱怨他們的數(shù)據(jù)庫(kù)沒有達(dá)到希望的要求而與你聯(lián)系時(shí),這樣做對(duì)非客戶機(jī)/服務(wù)器環(huán)境特別有用。

4) 包含版本機(jī)制

在數(shù)據(jù)庫(kù)中引入版本控制機(jī)制來確定使用中的數(shù)據(jù)庫(kù)的版本。時(shí)間一長(zhǎng),用戶的需求總是會(huì)改變的。最終可能會(huì)要求修改數(shù)據(jù)庫(kù)結(jié)構(gòu)。把版本信息直接存放到數(shù)據(jù)庫(kù)中更為方便。

5) 編制文檔

對(duì)所有的快捷方式、命名規(guī)范、限制和函數(shù)都要編制文檔。

采用給表、列、觸發(fā)器等加注釋的數(shù)據(jù)庫(kù)工具。對(duì)開發(fā)、支持和跟蹤修改非常有用。

對(duì)數(shù)據(jù)庫(kù)文檔化,或者在數(shù)據(jù)庫(kù)自身的內(nèi)部或者單獨(dú)建立文檔。這樣,當(dāng)過了一年多時(shí)間后再回過頭來做第2 個(gè)版本,犯錯(cuò)的機(jī)會(huì)將大大減少。

6) 測(cè)試、測(cè)試、反復(fù)測(cè)試

建立或者修訂數(shù)據(jù)庫(kù)之后,必須用用戶新輸入的數(shù)據(jù)測(cè)試數(shù)據(jù)字段。最重要的是,讓用戶進(jìn)行測(cè)試并且同用戶一道保證選擇的數(shù)據(jù)類型滿足商業(yè)要求。測(cè)試需要在把新數(shù)據(jù)庫(kù)投入實(shí)際服務(wù)之前完成。

7) 檢查設(shè)計(jì)

在開發(fā)期間檢查數(shù)據(jù)庫(kù)設(shè)計(jì)的常用技術(shù)是通過其所支持的應(yīng)用程序原型檢查數(shù)據(jù)庫(kù)。換句話說,針對(duì)每一種最終表達(dá)數(shù)據(jù)的原型應(yīng)用,保證你檢查了數(shù)據(jù)模型并且查看如何取出數(shù)據(jù)。

三、數(shù)據(jù)庫(kù)命名規(guī)范

1. 實(shí)體(表)的命名

1) 表以名詞或名詞短語(yǔ)命名,確定表名是采用復(fù)數(shù)還是單數(shù)形式,此外給表的別名定義簡(jiǎn)單規(guī)則(比方說,如果表名是一個(gè)單詞,別名就取單詞的前4 個(gè)字母;如果表名是兩個(gè)單詞,就各取兩個(gè)單詞的前兩個(gè)字母組成4 個(gè)字母長(zhǎng)的別名;如果表的名字由3 個(gè)單詞組成,從頭兩個(gè)單詞中各取一個(gè)然后從最后一個(gè)單詞中再取出兩個(gè)字母,結(jié)果還是組成4 字母長(zhǎng)的別名,其余依次類推)

對(duì)工作用表來說,表名可以加上前綴WORK_ 后面附上采用該表的應(yīng)用程序的名字。在命名過程當(dāng)中,根據(jù)語(yǔ)義拼湊縮寫即可。注意,由于ORCLE會(huì)將字段名稱統(tǒng)一成大寫或者小寫中的一種,所以要求加上下劃線。

舉例:

定義的縮寫 Sales: Sal 銷售;

Order: Ord 訂單;

Detail: Dtl 明細(xì);

則銷售訂單明細(xì)表命名為:Sal_Ord_Dtl;

2) 如果表或者是字段的名稱僅有一個(gè)單詞,那么建議不使用縮寫,而是用完整的單詞。

舉例:

定義的縮寫 Material Ma 物品;

物品表名為:Material, 而不是 Ma.

但是字段物品編碼則是:Ma_ID;而不是Material_ID

3) 所有的存儲(chǔ)值列表的表前面加上前綴Z

目的是將這些值列表類排序在數(shù)據(jù)庫(kù)最后。

4) 所有的冗余類的命名(主要是累計(jì)表)前面加上前綴X

冗余類是為了提高數(shù)據(jù)庫(kù)效率,非規(guī)范化數(shù)據(jù)庫(kù)的時(shí)候加入的字段或者表

5) 關(guān)聯(lián)類通過用下劃線連接兩個(gè)基本類之后,再加前綴R的方式命名,后面按照字母順序羅列兩個(gè)表名或者表名的縮寫。

關(guān)聯(lián)表用于保存多對(duì)多關(guān)系。

如果被關(guān)聯(lián)的表名大于10個(gè)字母,必須將原來的表名的進(jìn)行縮寫。如果沒有其他原因,建議都使用縮寫。

舉例:表Object與自身存在多對(duì)多的關(guān)系,則保存多對(duì)多關(guān)系的表命名為:R_Object;

表 Depart和Employee;存在多對(duì)多的關(guān)系;則關(guān)聯(lián)表命名為R_Dept_Emp

2. 屬性(列)的命名

1) 采用有意義的列名,表內(nèi)的列要針對(duì)鍵采用一整套設(shè)計(jì)規(guī)則。每一個(gè)表都將有一個(gè)自動(dòng)ID作為主健,邏輯上的主健作為第一組候選主健來定義,如果是數(shù)據(jù)庫(kù)自動(dòng)生成的編碼,統(tǒng)一命名為:ID;如果是自定義的邏輯上的編碼則用縮寫加“ID”的方法命名。如果鍵是數(shù)字類型,你可以用_NO 作為后綴;如果是字符類型則可以采用_CODE 后綴。對(duì)列名應(yīng)該采用標(biāo)準(zhǔn)的前綴和后綴。

舉例:銷售訂單的編號(hào)字段命名:Sal_Ord_ID;如果還存在一個(gè)數(shù)據(jù)庫(kù)生成的自動(dòng)編號(hào),則命名為:ID。

2) 所有的屬性加上有關(guān)類型的后綴,注意,如果還需要其它的后綴,都放在類型后綴之前。

注: 數(shù)據(jù)類型是文本的字段,類型后綴TX可以不寫。有些類型比較明顯的字段,可以不寫類型后綴。

3) 采用前綴命名

給每個(gè)表的列名都采用統(tǒng)一的前綴,那么在編寫SQL表達(dá)式的時(shí)候會(huì)得到大大的簡(jiǎn)化。這樣做也確實(shí)有缺點(diǎn),比如破壞了自動(dòng)表連接工具的作用,后者把公共列名同某些數(shù)據(jù)庫(kù)聯(lián)系起來。

3. 視圖的命名

1) 視圖以V作為前綴,其他命名規(guī)則和表的命名類似;

2) 命名應(yīng)盡量體現(xiàn)各視圖的功能。

4. 觸發(fā)器的命名

觸發(fā)器以TR作為前綴,觸發(fā)器名為相應(yīng)的表名加上后綴,Insert觸發(fā)器加'_I',Delete觸發(fā)器加'_D',Update觸發(fā)器加'_U',如:TR_Customer_I,TR_Customer_D,TR_Customer_U。

5. 存儲(chǔ)過程名

存儲(chǔ)過程應(yīng)以'UP_'開頭,和系統(tǒng)的存儲(chǔ)過程區(qū)分,后續(xù)部分主要以動(dòng)賓形式構(gòu)成,并用下劃線分割各個(gè)組成部分。如增加代理商的帳戶的存儲(chǔ)過程為'UP_Ins_Agent_Account'。

6. 變量名

變量名采用小寫,若屬于詞組形式,用下劃線分隔每個(gè)單詞,如@my_err_no。

7. 命名中其他注意事項(xiàng)

1) 以上命名都不得超過30個(gè)字符的系統(tǒng)限制。變量名的長(zhǎng)度限制為29(不包括標(biāo)識(shí)字符@)。

2) 數(shù)據(jù)對(duì)象、變量的命名都采用英文字符,禁止使用中文命名。絕對(duì)不要在對(duì)象名的字符之間留空格。

3) 小心保留詞,要保證你的字段名沒有和保留詞、數(shù)據(jù)庫(kù)系統(tǒng)或者常用訪問方法沖突

5) 保持字段名和類型的一致性,在命名字段并為其指定數(shù)據(jù)類型的時(shí)候一定要保證一致性。假如數(shù)據(jù)類型在一個(gè)表里是整數(shù),那在另一個(gè)表里可就別變成字符型了。

計(jì)算機(jī)論文如何寫

首先是選題,一般老師都會(huì)提供若干個(gè)選題給你選,其中必然包括幾個(gè)“XX系統(tǒng)的設(shè)計(jì)與開發(fā)”,這樣的選題就是符合我們前面的假設(shè)和預(yù)想的。盤他!假設(shè)我現(xiàn)在選了一個(gè)題目是“基于SSM的XX網(wǎng)上商城的設(shè)計(jì)與開發(fā)”。

選完題目就面臨著一個(gè)問題:是先做開發(fā)還是先寫文章,或者是一邊寫一邊開發(fā)。我的建議是一邊寫一邊開發(fā)。原因是:開發(fā)的過程是需要寫一些文案的,比如需求分析、數(shù)據(jù)庫(kù)的表結(jié)構(gòu)的關(guān)系、整個(gè)系統(tǒng)的交互邏輯等等。而這些文案是可以出現(xiàn)在我們的論文當(dāng)中的。

那接下來就說一下如何開發(fā)和寫文論,當(dāng)然某些開發(fā)過程我只能粗略的說一下。

1.摘要:

這是所有論文的第一個(gè)小title,說他惡心有時(shí)候也惡心,說他簡(jiǎn)單也是蠻簡(jiǎn)單的。那么這一部分究竟是要寫什么的?由于這一部分需要展現(xiàn)出做這個(gè)系統(tǒng)的必要性、開發(fā)這個(gè)系統(tǒng)的實(shí)現(xiàn)方式、系統(tǒng)的功能和系統(tǒng)的作用。所以可以這樣寫:

隨著中國(guó)經(jīng)濟(jì)的高速發(fā)展以及網(wǎng)絡(luò)技術(shù)的普及,互聯(lián)網(wǎng)的技術(shù)得到全面的發(fā)展,中國(guó)的各行各業(yè)都在互聯(lián)網(wǎng)的影響下發(fā)生了變革?;ヂ?lián)網(wǎng)的快速發(fā)展催生了許多產(chǎn)業(yè),其中最具代表性的便是電子商務(wù),電子商務(wù)使得企業(yè)和客戶的營(yíng)銷關(guān)系由實(shí)體店銷售準(zhǔn)換為網(wǎng)絡(luò)電子商務(wù)營(yíng)銷。馬云曾說:“讓天底下沒有難做的生意”,越來越多的店家選擇在網(wǎng)上開店,使得交易不再限制于天南地北,同時(shí)也大大降低了店家的經(jīng)營(yíng)成本,在提高收益的同時(shí),也方便了客戶,本課題正式在這種背景下應(yīng)運(yùn)而生。

本課題介紹了“基于SSM的XX網(wǎng)上商城”的開發(fā)環(huán)境、需求分析、界面設(shè)計(jì)和數(shù)據(jù)庫(kù)設(shè)計(jì)以及涉及到的框架。

本系統(tǒng)采用了B/S架構(gòu),使用了Java、HTML、JS等語(yǔ)言,使用了主流的后臺(tái)開發(fā)框架SSM(spring+springMVC+Mybatis),以及采用了開源的輕量級(jí)數(shù)據(jù)庫(kù)Mysql進(jìn)行開發(fā),為網(wǎng)絡(luò)商城提供了前端展示和后臺(tái)管理的模塊,實(shí)現(xiàn)了注冊(cè)、登錄以及購(gòu)物等主要功能,為消費(fèi)者提供了便捷快速的購(gòu)物體驗(yàn),以及為提高了店家的銷售效率。

關(guān)鍵字:網(wǎng)上商城,SSM,Java,HTML,JS,MySQL

(關(guān)鍵字一般就是把摘要中提及到的關(guān)鍵性技術(shù)提取出來,讓閱讀者一目了然,知道哪些是重點(diǎn))

Abstract:......

(英文摘要建議谷歌翻譯,然后把明顯錯(cuò)誤的地方修改一下即可)

2.第一章:引言

這一部分也是比虛的,其實(shí)隨便扯一扯就可以了,一般包含以下幾部分1.背景2.研究?jī)?nèi)容。其中背景主要講一些關(guān)于社會(huì)發(fā)展的趨勢(shì)導(dǎo)致了一些什么問題,而這些問題又應(yīng)該如何去解決,多說幾句,寫到兩三百字即可。研究?jī)?nèi)容就是針對(duì)上述的背景我們?nèi)绾芜M(jìn)行改進(jìn)。細(xì)心的同學(xué)可能會(huì)說,感覺跟摘要有些重復(fù)。是的!這兩部分內(nèi)容其實(shí)是挺重復(fù)的,但是沒關(guān)系,不過不要使用完完全全一樣的話去描述,因?yàn)樽詈笳撐牟橹氐臅r(shí)候會(huì)對(duì)文章自引用進(jìn)行查重的。這一部分也是三五百字即可。

3.第二章:系統(tǒng)的開發(fā)技術(shù)介紹

這一部分是需要我們?cè)谡介_發(fā)之前做好的技術(shù)調(diào)研,然后對(duì)這一部分的技術(shù)進(jìn)行詳細(xì)的介紹。這一部分我不可能細(xì)講,因?yàn)閮?nèi)容太多了,而且對(duì)于不同的項(xiàng)目有不同的內(nèi)容,在查閱資料的過程也是提升技術(shù)的一個(gè)重要的環(huán)節(jié),你可以真真切切的了解到開發(fā)一個(gè)工程是需要哪方面的知識(shí),因此我就對(duì)我所選的這個(gè)課題應(yīng)該使用到的技術(shù)棧進(jìn)行一下介紹,也算是拋磚引玉,各位同學(xué)可以根據(jù)自己的實(shí)際情況進(jìn)行撰寫。

開發(fā)不同的系統(tǒng)雖然涉及到的業(yè)務(wù)邏輯不同,處理方式也千差萬別,但是本質(zhì)上都是一樣的,都是前端界面通過服務(wù)器跟數(shù)據(jù)庫(kù)進(jìn)行數(shù)據(jù)交互的一個(gè)過程,涉及到的內(nèi)容也無非就是前端、后臺(tái)和服務(wù)器。但是有一個(gè)需要注意的點(diǎn),就是不要把HTML、JAVA等使用的語(yǔ)言介紹也給堆在這里,老師沒細(xì)看還好,細(xì)看還是會(huì)顯得太水字?jǐn)?shù)了,記住,寫工程性的課題不怕沒字?jǐn)?shù)。那問題來了,語(yǔ)言介紹不給寫那應(yīng)該些什么呢?應(yīng)該寫涉及到的框架、使用的工具。這些就夠了,隨隨便便就幾千字了。下面舉例簡(jiǎn)單說明一下。

a. 前端

強(qiáng)調(diào)一下,不要把HTML、CSS等一下前端的規(guī)范展開來寫,可以輕描淡寫,但篇幅不能過多。這里可以寫前端框架的使用,比如使用npm管理包(可以介紹一下npm以及在工程中的使用)、vue的使用(同樣可以介紹vue框架以及應(yīng)用)、element(element以及使用他的好處)等等。也希望同學(xué)在做畢設(shè)的過程中要真的去了解這些技術(shù)并且去使用它,相信我,看完再去用你的技術(shù)會(huì)有質(zhì)的飛躍。

b. 后臺(tái)

這一部分是重點(diǎn),對(duì)于本課題來說,標(biāo)題就寫了是基于SSM的。對(duì)于這個(gè)java框架并不熟悉的同學(xué)來說建議先去查一下資料,而且很多同學(xué)會(huì)有疑問,使用技術(shù)框架的目的就是為了讓開發(fā)更加的便捷和快速,但是為什么我們自己在開發(fā)的過程中會(huì)感覺好像變得更加復(fù)雜?很負(fù)責(zé)任的告訴你,是正常的。因?yàn)榭蚣懿粌H會(huì)幫我們封裝好一些常用的方法,而且會(huì)考慮到更新迭代以及代碼可讀性等等的一系列的問題,某些規(guī)定和配置我們之所以沒有感受到他的好處是因?yàn)檫@種校園內(nèi)的開發(fā)并不涉及生產(chǎn)問題,也不會(huì)有很多的更新迭代,更加不會(huì)考慮到代碼的可讀性。例如spring的工廠,一開始使用的時(shí)候很多同學(xué)會(huì)覺得為什么我new一個(gè)類的時(shí)候還要去改配置文件,直接new不香嗎?直接new是很香,但是你考慮到真正去工作的時(shí)候,假設(shè)你要改類的一些關(guān)系的時(shí)候,還要去改代碼,當(dāng)工程一大,代碼去哪里找呢?一個(gè)一個(gè)文件看嗎?顯然是非常不可取的,效率非常低,這個(gè)時(shí)候配置文件的優(yōu)勢(shì)就發(fā)揮出來了,直接修改配置文件,不需要更改代碼,耦合性也大大的降低。好像跑題了,說了這么多就告訴同學(xué)們,要沉住氣,理解框架這樣設(shè)計(jì)背后的原因,對(duì)大家自身技術(shù)的提高非常的有幫助!

那這一部分我們就可以介紹spring(包括spring的IOC、spring的工廠、spring的AOP等等,并且可以在論文中強(qiáng)調(diào)如何應(yīng)用到我們的系統(tǒng)當(dāng)中)、springMVC(這一部分可以講解srpingMVC作為一個(gè)連接前端和數(shù)據(jù)庫(kù)的工具在實(shí)際工作過程中的具體流程,也可以講述springMVC的分層的概念以及如何應(yīng)用)、Mybatis(包括跟JDBC的關(guān)系、mybatis依賴的配置、使用到的接口、動(dòng)態(tài)代理、一級(jí)緩存和二級(jí)緩存以及延遲加載等等的一些技術(shù)問題)

c. 服務(wù)器和數(shù)據(jù)庫(kù)

這一部分可以介紹一下用來搭建服務(wù)器的工具和所使用的數(shù)據(jù)庫(kù)。假設(shè)你是使用了云服務(wù)器來搭建了,可以詳細(xì)介紹一下云服務(wù)器的搭建過程包括防火墻、端口等等內(nèi)容。一般服務(wù)器使用tomcat進(jìn)行搭建,可以把tomcat介紹一下并且介紹一下tomcat是如何監(jiān)聽和解析用戶請(qǐng)求的具體流程。

一般小型的項(xiàng)目采用MySQL作為數(shù)據(jù)庫(kù),可以詳細(xì)說一下選擇MySQL的原因,比如相對(duì)于Oracle的好處。可以介紹一下MySQL數(shù)據(jù)庫(kù)的一些特點(diǎn)包括分頁(yè)、是否支持事務(wù)等等。

4.第三章:需求分析

這一部分是針對(duì)具體的業(yè)務(wù)場(chǎng)景來分析需要開發(fā)哪些功能,這一部分可以讓你感受一下產(chǎn)品經(jīng)理的職責(zé),只不過不需要跟程序員對(duì)接,因?yàn)槟阕约壕褪浅绦騿T哈哈。一般來說分成兩部分就可以了,一部分是對(duì)于前端的業(yè)務(wù)流程,另一部分就是后臺(tái)服務(wù)器的業(yè)務(wù)流程,可以使用一些軟件來繪畫流程圖,想圖個(gè)方便可以直接使用word自帶的圖形進(jìn)行編寫,也不至于難看,就比較簡(jiǎn)約。想做的好看點(diǎn)的話個(gè)人推薦使用xmind,非常簡(jiǎn)單,可以快速做出美觀的流程圖。如果沒有什么思路,那前端就按照著使用者的邏輯去寫,比如用戶需要注冊(cè)、登錄、找回密碼、購(gòu)物、退貨等操作,那后端就對(duì)應(yīng)著這些前端邏輯需要有相應(yīng)的業(yè)務(wù)處理。個(gè)人感覺這一部分比較好寫,就不再贅述。

5.第四章:系統(tǒng)的設(shè)計(jì)和實(shí)現(xiàn)

這一部分可以挑選一些有代表性的功能出來細(xì)講,有些同學(xué)可能會(huì)有疑問,論文可不可以貼代碼呢?答案是可以的。但是我個(gè)人的建議是貼偽代碼,不要把你寫的長(zhǎng)篇大論的代碼全部放進(jìn)去,不好看而且邏輯混亂,應(yīng)該做的是把代碼抽取為偽代碼,貼代碼的目的是為了讓閱讀者清晰地讀懂你是如何實(shí)現(xiàn)這個(gè)功能的,他并不會(huì)在意你的語(yǔ)法你的命名。下面列舉若干個(gè)可以寫的內(nèi)容,并不限于此。

a. SSM框架的整合。如何使用Spring來整合并且管理SpringMVC和Mybatis.

b. 客戶登錄狀態(tài)保存的實(shí)現(xiàn)。這一部分可能會(huì)涉及到cookies,sessions以及http報(bào)文解析等等,都可以詳解。

c. 后臺(tái)商品管理的功能。這一部分可以根據(jù)管理員的后臺(tái)管理功能進(jìn)行描寫。

d. 商品搜索功能??梢陨婕暗綌?shù)據(jù)庫(kù)的模糊搜索。

e. 數(shù)據(jù)庫(kù)表格的設(shè)計(jì)??梢泽w現(xiàn)數(shù)據(jù)庫(kù)表格設(shè)計(jì)的時(shí)候如何遵守三范式。

f. 可以寫在開發(fā)過程中遇到的一些疑難雜癥。

g. 可以寫開發(fā)過程中使用到的一些比較具有亮點(diǎn)的語(yǔ)言特性。比如java的多線程、lambda表達(dá)式。又比如實(shí)現(xiàn)注冊(cè)功能的時(shí)候使用的正則表達(dá)式。

……

等等數(shù)不勝數(shù)。

6.第五章:運(yùn)行結(jié)果

這一部分非常好寫了。截取一些關(guān)于你的系統(tǒng)的界面并且介紹一下功能,盡量說詳細(xì)點(diǎn),就ok了。

7.第六章:總結(jié)以及展望

這一部分也是比較水的一部分,但是也希望同學(xué)們認(rèn)真寫一寫。可以寫一下你開發(fā)這個(gè)項(xiàng)目的過程中學(xué)習(xí)到了什么,可以是XX技術(shù),也可以是艱苦奮斗的精神……。展望可以寫有望發(fā)展成另外一個(gè)淘寶……開玩笑開玩笑,總之劈里啪啦湊個(gè)幾百字即可。

8.參考文獻(xiàn)

把你開發(fā)過程中參考過的文章、論文貼進(jìn)去之后,往往會(huì)發(fā)現(xiàn)參考文獻(xiàn)不夠,太少了!那怎么辦呢?那就貼一些關(guān)于使用的技術(shù)的文章或者參考手冊(cè)咯,雖然大部分是沒看過的,但是還是希望大家可以多少看一看(正義之氣躍然紙上)。去知網(wǎng)查找參考文章然后添加到你的參考文獻(xiàn)是非常方便的,只需要找到對(duì)應(yīng)的文章并且選擇“引用”功能,即可自動(dòng)生成引用的文字,直接復(fù)制到你的論文中。

9.致謝

第一步,感謝你的導(dǎo)師,感謝你的院領(lǐng)導(dǎo),感謝你的校領(lǐng)導(dǎo)。說的好聽后可能答辯的時(shí)候不會(huì)太為難你……然后你要感謝你的家人你的舍友你的朋友或者是你家的狗(開玩笑),都可以的,這一部分又輕輕松松兩百字。

至此,一篇計(jì)算機(jī)論文就寫完了,是不是覺得挺簡(jiǎn)單的呢?以上內(nèi)容皆由學(xué)術(shù)堂提供整理。

mysql寫一篇文章用什么字段類型

CHAR 0-255字節(jié) 定長(zhǎng)字符串 VARCHAR 0-255字節(jié) 變長(zhǎng)字符串 TINYBLOB 0-255字節(jié) 不超過 255 個(gè)字符的二進(jìn)制字符串 TINYTEXT 0-255字節(jié) 短文本字符串 BLOB 0-65 535字節(jié) 二進(jìn)制形式的長(zhǎng)文本數(shù)據(jù) TEXT 0-65 535字節(jié) 長(zhǎng)文本數(shù)據(jù) MEDIUMBLOB 0-16 777 215字節(jié) 二進(jìn)制形式的中等長(zhǎng)度文本數(shù)據(jù) MEDIUMTEXT 0-16 777 215字節(jié) 中等長(zhǎng)度文本數(shù)據(jù) LOGNGBLOB 0-4 294 967 295字節(jié) 二進(jìn)制形式的極大文本數(shù)據(jù) LONGTEXT 0-4 294 967 295字節(jié) 極大文本數(shù)據(jù)


新聞名稱:MySQL論文怎么寫 2021中秋節(jié)要調(diào)休嗎
鏈接分享:http://weahome.cn/article/dogidpp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部