作為一個著重研究信息系統(tǒng)開發(fā)、應(yīng)用的專業(yè),計算機畢業(yè)論文的寫作應(yīng)該更貼合實際出來,可能有很多剛拿到題目的學(xué)生不知道改如何著手,下面我們就來了解一下計算機畢業(yè)論文怎么寫?
麻章ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
一、計算機畢業(yè)論文的寫作方法
1、前言部分
前言部分也常用"引論"、"概論"、"問題背景"等做標(biāo)題,在這部分中,主要介紹論文的選題。
首先要闡明選題的背景和選題的意義。選題需強調(diào)實際背景,說明在計算機研究中或部門信息化建設(shè)、企業(yè)管理現(xiàn)代化等工作中引發(fā)該問題的原因,問題出現(xiàn)的環(huán)境和條件,解決該問題后能起什么作用。結(jié)合問題背景的闡述,要使讀者感受到此選題確有實用價值和學(xué)術(shù)價值,因而有研究和開發(fā)的必要性。
前言部分常起到畫龍點睛的作用。選題實際又有新意,表明作者的研究方向正確,設(shè)計開發(fā)工作有價值。對一篇論文來說,前言寫好了,就會吸引讀者,使他們對作者的選題感興趣,愿意進(jìn)一步了解作者的工作成果。
?
2、綜述部分
任何一個課題的研究或開發(fā)都是有學(xué)科基礎(chǔ)或技術(shù)基礎(chǔ)的。綜述部分主要闡述選題在相應(yīng)學(xué)科領(lǐng)域中的發(fā)展進(jìn)程和研究方向,特別是近年來的發(fā)展趨勢和最新成果。通過與中外研究成果的比較和評論,說明自己的選題是符合當(dāng)前的研究方向并有所進(jìn)展,或采用了當(dāng)前的最新技術(shù)并有所改進(jìn),目的是使讀者進(jìn)一步了解選題的意義。
綜述部分能反映出畢業(yè)設(shè)計學(xué)生多方面的能力。首先是結(jié)合課題任務(wù)獨立查閱中外文獻(xiàn)資料的能力,通過查閱文獻(xiàn)資料,收集各種信息,了解同行的研究水平,在工作和論文中有效地運用文獻(xiàn),這不僅能避免簡單的重復(fù)研究,而且也能使論文工作有一個高起點。
其次,還能反映出綜合分析的能力。從大量的文獻(xiàn)中找到可以借鑒和參考的信息,這不僅要有一定的專業(yè)知識水平,還要有一定的綜合能力。對同行研究成果是否能抓住要點,優(yōu)缺點的評述是否符合實際,恰到好處,這和一個人的分析理解能力是有關(guān)的。
值得注意的是,要做好一篇畢業(yè)論文,必須閱讀一定量(2~3篇)的近期外文資料,這不僅反映自己的外文閱讀能力,而且有助于體現(xiàn)論文的先進(jìn)性。
3、方案論證
在明確了所要解決的問題和課題綜述后,很自然地就要提出自己解決問題的思路和方案。在寫作方法上,一是要通過比較,顯示自己方案的價值,二是讓讀者了解方案的獨到之處或有創(chuàng)新點的思路、算法和關(guān)鍵技術(shù)。
在與文獻(xiàn)資料中的方案進(jìn)行比較時,首先要闡述自己的設(shè)計方案,說明為什么要選擇或設(shè)計這樣的方案,前面評述的優(yōu)點在此方案中如何體現(xiàn),不足之處又是如何得到了克服,最后完成的工作能達(dá)到什么性能水平,有什么創(chuàng)新之處(或有新意)。如果自己的題目是總方案的一部分,一定要明確說明自己承擔(dān)的部分,以及對整個任務(wù)的貢獻(xiàn)。
4、論文主體
在這部分中,要將整個研究開發(fā)工作的內(nèi)容,包括理論分析、總體設(shè)計、模塊劃分、實現(xiàn)方法等進(jìn)行詳細(xì)的論述。論文主體部分要占4/5左右。主體部分的寫法,視選題的不同可以多樣,研究型論文和應(yīng)用開發(fā)型論文的寫法就有明顯的不同。
研究型的論文,主體部分一般應(yīng)包括:理論基礎(chǔ),數(shù)學(xué)模型,算法推導(dǎo),形式化描述,求解方法,軟硬件系統(tǒng)的實現(xiàn)及調(diào)試,測試數(shù)據(jù)的分析及結(jié)論。
要強調(diào)的是,研究型論文絕不是從推理到推理的空洞文章。研究型論文也應(yīng)有實際背景,也應(yīng)有到企業(yè)和實際部門調(diào)研的過程,并在實際調(diào)查研究中獲取信息,發(fā)現(xiàn)問題,收集數(shù)據(jù)和資料。在研究分析的基礎(chǔ)上,提出解決實際問題的、富有創(chuàng)建性的結(jié)論。
應(yīng)用開發(fā)型的論文,主體部分應(yīng)包括:總體設(shè)計,模塊劃分,算法描述,編程模型,數(shù)據(jù)結(jié)構(gòu),實現(xiàn)技術(shù),實例測試及性能分析。
以上內(nèi)容根據(jù)任務(wù)所處的階段不同,可以有所側(cè)重。在整個任務(wù)初期的論文,可側(cè)重于研究與設(shè)計,在任務(wù)后期的論文可側(cè)重于實現(xiàn)與應(yīng)用。但作為一篇完整的論文應(yīng)讓讀者從課題的原理設(shè)計,問題的解決方法,關(guān)鍵技術(shù)以及性能測試都有全面的了解,以便能準(zhǔn)確地評判論文的質(zhì)量。
論文主體部分的內(nèi)容一般要分成幾個章節(jié)來描述。在寫作上,除了用文字描述外,還要善于利用各種原理圖、流程圖、表格、曲線等來說明問題,一篇條理清晰,圖文并茂的論文才是一篇好的論文。
5、測試及性能分析
對理工專業(yè)的畢業(yè)設(shè)計論文,測試數(shù)據(jù)是性能評價的基礎(chǔ),必須真實可靠。通過測試數(shù)據(jù),論文工作的成效可一目了然。根據(jù)課題的要求,可以在實驗室環(huán)境下測試,也可以在工作現(xiàn)場測試。
在論文中,要將測試時的環(huán)境和條件列出,因為任何測試數(shù)據(jù)都與測試環(huán)境和條件相關(guān),不說明測試條件的數(shù)據(jù)是不可比的,因此也是無意義的。
測試一般包括功能測試和性能測試。功能測試是將課題完成的計算機軟硬件系統(tǒng)(子系統(tǒng))或應(yīng)用系統(tǒng)所要求達(dá)到的功能逐一進(jìn)行測試。性能測試一般是在系統(tǒng)(子系統(tǒng))的運行狀態(tài)下,記錄實例運行的數(shù)據(jù),然后,歸納和計算這些數(shù)據(jù),以此來分析系統(tǒng)運行的性能。
測試實例可以自己設(shè)計編寫,也可以選擇學(xué)科領(lǐng)域內(nèi)公認(rèn)的、有一定權(quán)威性的測試實例或測試集。原則是通過所選擇(設(shè)計)的實例的運行,既能準(zhǔn)確反映系統(tǒng)運行的功能和性能,與同類系統(tǒng)又有可比性。只有這樣,論文最后為自己工作所做的結(jié)論才有說服力。
6、結(jié)束語
這一節(jié)篇幅不大,首先對整個論文工作做一個簡單小結(jié),然后將自己在研究開發(fā)工作中所做的貢獻(xiàn),或獨立研究的成果列舉出來,再對自己工作的進(jìn)展、水平做一個實事求是的評論。但在用"首次提出"、"重大突破"、"重要價值"等自我評語時要慎重。
7、后記
在后記中,主要表達(dá)對導(dǎo)師和其他有關(guān)教師和同學(xué)的感謝之意。對此,仍要實事求是,過分的頌揚反而會帶來消極影響。這一節(jié)也可用"致謝"做標(biāo)題。
8、參考文獻(xiàn)
中外文的參考文獻(xiàn)應(yīng)按照規(guī)范列舉在論文最后。這一部分的編寫反映作者的學(xué)術(shù)作風(fēng)。編寫參考文獻(xiàn)要注意:(1)要嚴(yán)格按照規(guī)范編寫,特別是外文文獻(xiàn),不要漏寫、錯寫;(2)論文內(nèi)容和參考文獻(xiàn)要前后對應(yīng),正文中凡引用參考文獻(xiàn)的地方應(yīng)加注;(3)列出的文獻(xiàn)資料應(yīng)與論文課題相關(guān),無關(guān)的文獻(xiàn)只會使讀者感到作者的研究目標(biāo)很分散;(4)選擇的參考文獻(xiàn)應(yīng)主要是近期的。
二、計算機寫作注意事項
1、設(shè)計(論文)題目:按照小題目。封面XXXXX學(xué)院畢業(yè)設(shè)計(論文)、 屆 分院(系)
2、摘要:不要主語,英文中無法表達(dá)時可用被動語態(tài)
3、關(guān)鍵詞:體現(xiàn)設(shè)計(論文)主要工作的詞語
4、目錄:自動生成,1.1.1的格式,最多到1.1.1.1 5、正文中文獻(xiàn)引用要客觀,別人的成果要說明,不要據(jù)為己有;自己的成果要突出。不清楚的圖必須修改(可用word畫或者AutoCAD畫),表格盡量采用三線表
6、參考文獻(xiàn):至少要有兩篇英文文獻(xiàn)
7、致謝(不是致辭)
8、附錄(若多于一個附錄,可用附錄一、附錄二,……)
9、各部分格式要求,嚴(yán)格按照畢業(yè)設(shè)計手冊執(zhí)行
三、計算機論文編輯技巧
1、文檔結(jié)構(gòu)圖的妙用 格式修改時可先將全文設(shè)置為正文格式(新羅馬與宋體的博弈),然后將三級標(biāo)題以上標(biāo)題按照三級標(biāo)題提出來,再將二級標(biāo)題以上標(biāo)題按照二級標(biāo)題提出來,最后將一級標(biāo)題提出來。提出標(biāo)題時注意使用大綱級別。 提出大綱級別后,可用文檔結(jié)構(gòu)圖輕松導(dǎo)航文檔。還可自動生成目錄(插入-引用-索引和目錄-目錄)。
2、圖的裁剪與組合(建議采用浮于文字上方的方式)、文本框的妙用、公式的編輯(變量用斜體、下標(biāo)用的i、j、k用斜體,其余用正體。公式中出現(xiàn)漢字怎么辦?用拼音加加輸入法輸入漢字)
3、表格的編輯
4、上下標(biāo)的使用(自定義word菜單)
5、分節(jié)符的使用
6、目錄自動生成(頁碼的問題),目錄可單獨取文件名(寫字板的運用),也可放到正文前面
7、樣式與格式的自動更新功能
8、頁眉設(shè)置(去掉橫線)
9、文檔的備份(防止病毒感染、U盤丟失、計算機故障)
數(shù)據(jù)庫設(shè)計方法、規(guī)范與技巧
一、數(shù)據(jù)庫設(shè)計過程
數(shù)據(jù)庫技術(shù)是信息資源管理最有效的手段。數(shù)據(jù)庫設(shè)計是指對于一個給定的應(yīng)用環(huán)境,構(gòu)造最優(yōu)的數(shù)據(jù)庫模式,建立數(shù)據(jù)庫及其應(yīng)用系統(tǒng),有效存儲數(shù)據(jù),滿足用戶信息要求和處理要求。
數(shù)據(jù)庫設(shè)計中需求分析階段綜合各個用戶的應(yīng)用需求(現(xiàn)實世界的需求),在概念設(shè)計階段形成獨立于機器特點、獨立于各個DBMS產(chǎn)品的概念模式(信息世界模型),用E-R圖來描述。在邏輯設(shè)計階段將E-R圖轉(zhuǎn)換成具體的數(shù)據(jù)庫產(chǎn)品支持的數(shù)據(jù)模型如關(guān)系模型,形成數(shù)據(jù)庫邏輯模式。然后根據(jù)用戶處理的要求,安全性的考慮,在基本表的基礎(chǔ)上再建立必要的視圖(VIEW)形成數(shù)據(jù)的外模式。在物理設(shè)計階段根據(jù)DBMS特點和處理的需要,進(jìn)行物理存儲安排,設(shè)計索引,形成數(shù)據(jù)庫內(nèi)模式。
1. 需求分析階段
需求收集和分析,結(jié)果得到數(shù)據(jù)字典描述的數(shù)據(jù)需求(和數(shù)據(jù)流圖描述的處理需求)。
需求分析的重點是調(diào)查、收集與分析用戶在數(shù)據(jù)管理中的信息要求、處理要求、安全性與完整性要求。
需求分析的方法:調(diào)查組織機構(gòu)情況、調(diào)查各部門的業(yè)務(wù)活動情況、協(xié)助用戶明確對新系統(tǒng)的各種要求、確定新系統(tǒng)的邊界。
常用的調(diào)查方法有: 跟班作業(yè)、開調(diào)查會、請專人介紹、詢問、設(shè)計調(diào)查表請用戶填寫、查閱記錄。
分析和表達(dá)用戶需求的方法主要包括自頂向下和自底向上兩類方法。自頂向下的結(jié)構(gòu)化分析方法(Structured Analysis,簡稱SA方法)從最上層的系統(tǒng)組織機構(gòu)入手,采用逐層分解的方式分析系統(tǒng),并把每一層用數(shù)據(jù)流圖和數(shù)據(jù)字典描述。
數(shù)據(jù)流圖表達(dá)了數(shù)據(jù)和處理過程的關(guān)系。系統(tǒng)中的數(shù)據(jù)則借助數(shù)據(jù)字典(Data Dictionary,簡稱DD)來描述。
數(shù)據(jù)字典是各類數(shù)據(jù)描述的集合,它是關(guān)于數(shù)據(jù)庫中數(shù)據(jù)的描述,即元數(shù)據(jù),而不是數(shù)據(jù)本身。數(shù)據(jù)字典通常包括數(shù)據(jù)項、數(shù)據(jù)結(jié)構(gòu)、數(shù)據(jù)流、數(shù)據(jù)存儲和處理過程五個部分(至少應(yīng)該包含每個字段的數(shù)據(jù)類型和在每個表內(nèi)的主外鍵)。
數(shù)據(jù)項描述={數(shù)據(jù)項名,數(shù)據(jù)項含義說明,別名,數(shù)據(jù)類型,長度,
取值范圍,取值含義,與其他數(shù)據(jù)項的邏輯關(guān)系}
數(shù)據(jù)結(jié)構(gòu)描述={數(shù)據(jù)結(jié)構(gòu)名,含義說明,組成:{數(shù)據(jù)項或數(shù)據(jù)結(jié)構(gòu)}}
數(shù)據(jù)流描述={數(shù)據(jù)流名,說明,數(shù)據(jù)流來源,數(shù)據(jù)流去向,
組成:{數(shù)據(jù)結(jié)構(gòu)},平均流量,高峰期流量}
數(shù)據(jù)存儲描述={數(shù)據(jù)存儲名,說明,編號,流入的數(shù)據(jù)流,流出的數(shù)據(jù)流,
組成:{數(shù)據(jù)結(jié)構(gòu)},數(shù)據(jù)量,存取方式}
處理過程描述={處理過程名,說明,輸入:{數(shù)據(jù)流},輸出:{數(shù)據(jù)流},
處理:{簡要說明}}
2. 概念結(jié)構(gòu)設(shè)計階段
通過對用戶需求進(jìn)行綜合、歸納與抽象,形成一個獨立于具體DBMS的概念模型,可以用E-R圖表示。
概念模型用于信息世界的建模。概念模型不依賴于某一個DBMS支持的數(shù)據(jù)模型。概念模型可以轉(zhuǎn)換為計算機上某一DBMS支持的特定數(shù)據(jù)模型。
概念模型特點:
(1) 具有較強的語義表達(dá)能力,能夠方便、直接地表達(dá)應(yīng)用中的各種語義知識。
(2) 應(yīng)該簡單、清晰、易于用戶理解,是用戶與數(shù)據(jù)庫設(shè)計人員之間進(jìn)行交流的語言。
概念模型設(shè)計的一種常用方法為IDEF1X方法,它就是把實體-聯(lián)系方法應(yīng)用到語義數(shù)據(jù)模型中的一種語義模型化技術(shù),用于建立系統(tǒng)信息模型。
使用IDEF1X方法創(chuàng)建E-R模型的步驟如下所示:
2.1 第零步——初始化工程
這個階段的任務(wù)是從目的描述和范圍描述開始,確定建模目標(biāo),開發(fā)建模計劃,組織建模隊伍,收集源材料,制定約束和規(guī)范。收集源材料是這階段的重點。通過調(diào)查和觀察結(jié)果,業(yè)務(wù)流程,原有系統(tǒng)的輸入輸出,各種報表,收集原始數(shù)據(jù),形成了基本數(shù)據(jù)資料表。
2.2 第一步——定義實體
實體集成員都有一個共同的特征和屬性集,可以從收集的源材料——基本數(shù)據(jù)資料表中直接或間接標(biāo)識出大部分實體。根據(jù)源材料名字表中表示物的術(shù)語以及具有“代碼”結(jié)尾的術(shù)語,如客戶代碼、代理商代碼、產(chǎn)品代碼等將其名詞部分代表的實體標(biāo)識出來,從而初步找出潛在的實體,形成初步實體表。
2.3 第二步——定義聯(lián)系
IDEF1X模型中只允許二元聯(lián)系,n元聯(lián)系必須定義為n個二元聯(lián)系。根據(jù)實際的業(yè)務(wù)需求和規(guī)則,使用實體聯(lián)系矩陣來標(biāo)識實體間的二元關(guān)系,然后根據(jù)實際情況確定出連接關(guān)系的勢、關(guān)系名和說明,確定關(guān)系類型,是標(biāo)識關(guān)系、非標(biāo)識關(guān)系(強制的或可選的)還是非確定關(guān)系、分類關(guān)系。如果子實體的每個實例都需要通過和父實體的關(guān)系來標(biāo)識,則為標(biāo)識關(guān)系,否則為非標(biāo)識關(guān)系。非標(biāo)識關(guān)系中,如果每個子實體的實例都與而且只與一個父實體關(guān)聯(lián),則為強制的,否則為非強制的。如果父實體與子實體代表的是同一現(xiàn)實對象,那么它們?yōu)榉诸愱P(guān)系。
2.4 第三步——定義碼
通過引入交叉實體除去上一階段產(chǎn)生的非確定關(guān)系,然后從非交叉實體和獨立實體開始標(biāo)識侯選碼屬性,以便唯一識別每個實體的實例,再從侯選碼中確定主碼。為了確定主碼和關(guān)系的有效性,通過非空規(guī)則和非多值規(guī)則來保證,即一個實體實例的一個屬性不能是空值,也不能在同一個時刻有一個以上的值。找出誤認(rèn)的確定關(guān)系,將實體進(jìn)一步分解,最后構(gòu)造出IDEF1X模型的鍵基視圖(KB圖)。
2.5 第四步——定義屬性
從源數(shù)據(jù)表中抽取說明性的名詞開發(fā)出屬性表,確定屬性的所有者。定義非主碼屬性,檢查屬性的非空及非多值規(guī)則。此外,還要檢查完全依賴函數(shù)規(guī)則和非傳遞依賴規(guī)則,保證一個非主碼屬性必須依賴于主碼、整個主碼、僅僅是主碼。以此得到了至少符合關(guān)系理論第三范式的改進(jìn)的IDEF1X模型的全屬性視圖。
2.6 第五步——定義其他對象和規(guī)則
定義屬性的數(shù)據(jù)類型、長度、精度、非空、缺省值、約束規(guī)則等。定義觸發(fā)器、存儲過程、視圖、角色、同義詞、序列等對象信息。
3. 邏輯結(jié)構(gòu)設(shè)計階段
將概念結(jié)構(gòu)轉(zhuǎn)換為某個DBMS所支持的數(shù)據(jù)模型(例如關(guān)系模型),并對其進(jìn)行優(yōu)化。設(shè)計邏輯結(jié)構(gòu)應(yīng)該選擇最適于描述與表達(dá)相應(yīng)概念結(jié)構(gòu)的數(shù)據(jù)模型,然后選擇最合適的DBMS。
將E-R圖轉(zhuǎn)換為關(guān)系模型實際上就是要將實體、實體的屬性和實體之間的聯(lián)系轉(zhuǎn)化為關(guān)系模式,這種轉(zhuǎn)換一般遵循如下原則:
1)一個實體型轉(zhuǎn)換為一個關(guān)系模式。實體的屬性就是關(guān)系的屬性。實體的碼就是關(guān)系的碼。
2)一個m:n聯(lián)系轉(zhuǎn)換為一個關(guān)系模式。與該聯(lián)系相連的各實體的碼以及聯(lián)系本身的屬性均轉(zhuǎn)換為關(guān)系的屬性。而關(guān)系的碼為各實體碼的組合。
3)一個1:n聯(lián)系可以轉(zhuǎn)換為一個獨立的關(guān)系模式,也可以與n端對應(yīng)的關(guān)系模式合并。如果轉(zhuǎn)換為一個獨立的關(guān)系模式,則與該聯(lián)系相連的各實體的碼以及聯(lián)系本身的屬性均轉(zhuǎn)換為關(guān)系的屬性,而關(guān)系的碼為n端實體的碼。
4)一個1:1聯(lián)系可以轉(zhuǎn)換為一個獨立的關(guān)系模式,也可以與任意一端對應(yīng)的關(guān)系模式合并。
5)三個或三個以上實體間的一個多元聯(lián)系轉(zhuǎn)換為一個關(guān)系模式。與該多元聯(lián)系相連的各實體的碼以及聯(lián)系本身的屬性均轉(zhuǎn)換為關(guān)系的屬性。而關(guān)系的碼為各實體碼的組合。
6)同一實體集的實體間的聯(lián)系,即自聯(lián)系,也可按上述1:1、1:n和m:n三種情況分別處理。
7)具有相同碼的關(guān)系模式可合并。
為了進(jìn)一步提高數(shù)據(jù)庫應(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)系模式分別屬于第幾范式。確定是否要對它們進(jìn)行合并或分解。一般來說將關(guān)系分解為3NF的標(biāo)準(zhǔn),即:
表內(nèi)的每一個值都只能被表達(dá)一次。
??表內(nèi)的每一行都應(yīng)該被唯一的標(biāo)識(有唯一鍵)。
表內(nèi)不應(yīng)該存儲依賴于其他鍵的非鍵信息。
4. 數(shù)據(jù)庫物理設(shè)計階段
為邏輯數(shù)據(jù)模型選取一個最適合應(yīng)用環(huán)境的物理結(jié)構(gòu)(包括存儲結(jié)構(gòu)和存取方法)。根據(jù)DBMS特點和處理的需要,進(jìn)行物理存儲安排,設(shè)計索引,形成數(shù)據(jù)庫內(nèi)模式。
5. 數(shù)據(jù)庫實施階段
運用DBMS提供的數(shù)據(jù)語言(例如SQL)及其宿主語言(例如C),根據(jù)邏輯設(shè)計和物理設(shè)計的結(jié)果建立數(shù)據(jù)庫,編制與調(diào)試應(yīng)用程序,組織數(shù)據(jù)入庫,并進(jìn)行試運行。 數(shù)據(jù)庫實施主要包括以下工作:用DDL定義數(shù)據(jù)庫結(jié)構(gòu)、組織數(shù)據(jù)入庫 、編制與調(diào)試應(yīng)用程序、數(shù)據(jù)庫試運行 6. 數(shù)據(jù)庫運行和維護(hù)階段
數(shù)據(jù)庫應(yīng)用系統(tǒng)經(jīng)過試運行后即可投入正式運行。在數(shù)據(jù)庫系統(tǒng)運行過程中必須不斷地對其進(jìn)行評價、調(diào)整與修改。包括:數(shù)據(jù)庫的轉(zhuǎn)儲和恢復(fù)、數(shù)據(jù)庫的安全性、完整性控制、數(shù)據(jù)庫性能的監(jiān)督、分析和改進(jìn)、數(shù)據(jù)庫的重組織和重構(gòu)造。
建模工具的使用
為加快數(shù)據(jù)庫設(shè)計速度,目前有很多數(shù)據(jù)庫輔助工具(CASE工具),如Rational公司的Rational Rose,CA公司的Erwin和Bpwin,Sybase公司的PowerDesigner以及Oracle公司的Oracle Designer等。
ERwin主要用來建立數(shù)據(jù)庫的概念模型和物理模型。它能用圖形化的方式,描述出實體、聯(lián)系及實體的屬性。ERwin支持IDEF1X方法。通過使用ERwin建模工具自動生成、更改和分析IDEF1X模型,不僅能得到優(yōu)秀的業(yè)務(wù)功能和數(shù)據(jù)需求模型,而且可以實現(xiàn)從IDEF1X模型到數(shù)據(jù)庫物理設(shè)計的轉(zhuǎn)變。ERwin工具繪制的模型對應(yīng)于邏輯模型和物理模型兩種。在邏輯模型中,IDEF1X工具箱可以方便地用圖形化的方式構(gòu)建和繪制實體聯(lián)系及實體的屬性。在物理模型中,ERwin可以定義對應(yīng)的表、列,并可針對各種數(shù)據(jù)庫管理系統(tǒng)自動轉(zhuǎn)換為適當(dāng)?shù)念愋汀?/p>
設(shè)計人員可根據(jù)需要選用相應(yīng)的數(shù)據(jù)庫設(shè)計建模工具。例如需求分析完成之后,設(shè)計人員可以使用Erwin畫ER圖,將ER圖轉(zhuǎn)換為關(guān)系數(shù)據(jù)模型,生成數(shù)據(jù)庫結(jié)構(gòu);畫數(shù)據(jù)流圖,生成應(yīng)用程序。
二、數(shù)據(jù)庫設(shè)計技巧
1. 設(shè)計數(shù)據(jù)庫之前(需求分析階段)
1) 理解客戶需求,詢問用戶如何看待未來需求變化。讓客戶解釋其需求,而且隨著開發(fā)的繼續(xù),還要經(jīng)常詢問客戶保證其需求仍然在開發(fā)的目的之中。
2) 了解企業(yè)業(yè)務(wù)可以在以后的開發(fā)階段節(jié)約大量的時間。
3) 重視輸入輸出。
在定義數(shù)據(jù)庫表和字段需求(輸入)時,首先應(yīng)檢查現(xiàn)有的或者已經(jīng)設(shè)計出的報表、查詢和視圖(輸出)以決定為了支持這些輸出哪些是必要的表和字段。
舉例:假如客戶需要一個報表按照郵政編碼排序、分段和求和,你要保證其中包括了單獨的郵政編碼字段而不要把郵政編碼糅進(jìn)地址字段里。
4) 創(chuàng)建數(shù)據(jù)字典和ER 圖表
ER 圖表和數(shù)據(jù)字典可以讓任何了解數(shù)據(jù)庫的人都明確如何從數(shù)據(jù)庫中獲得數(shù)據(jù)。ER圖對表明表之間關(guān)系很有用,而數(shù)據(jù)字典則說明了每個字段的用途以及任何可能存在的別名。對SQL 表達(dá)式的文檔化來說這是完全必要的。
5) 定義標(biāo)準(zhǔn)的對象命名規(guī)范
數(shù)據(jù)庫各種對象的命名必須規(guī)范。
2. 表和字段的設(shè)計(數(shù)據(jù)庫邏輯設(shè)計)
表設(shè)計原則
1) 標(biāo)準(zhǔn)化和規(guī)范化
數(shù)據(jù)的標(biāo)準(zhǔn)化有助于消除數(shù)據(jù)庫中的數(shù)據(jù)冗余。標(biāo)準(zhǔn)化有好幾種形式,但Third Normal Form(3NF)通常被認(rèn)為在性能、擴展性和數(shù)據(jù)完整性方面達(dá)到了最好平衡。簡單來說,遵守3NF 標(biāo)準(zhǔn)的數(shù)據(jù)庫的表設(shè)計原則是:“One Fact in One Place”即某個表只包括其本身基本的屬性,當(dāng)不是它們本身所具有的屬性時需進(jìn)行分解。表之間的關(guān)系通過外鍵相連接。它具有以下特點:有一組表專門存放通過鍵連接起來的關(guān)聯(lián)數(shù)據(jù)。
舉例:某個存放客戶及其有關(guān)定單的3NF 數(shù)據(jù)庫就可能有兩個表:Customer 和Order。Order 表不包含定單關(guān)聯(lián)客戶的任何信息,但表內(nèi)會存放一個鍵值,該鍵指向Customer 表里包含該客戶信息的那一行。
事實上,為了效率的緣故,對表不進(jìn)行標(biāo)準(zhǔn)化有時也是必要的。
2) 數(shù)據(jù)驅(qū)動
采用數(shù)據(jù)驅(qū)動而非硬編碼的方式,許多策略變更和維護(hù)都會方便得多,大大增強系統(tǒng)的靈活性和擴展性。
舉例,假如用戶界面要訪問外部數(shù)據(jù)源(文件、XML 文檔、其他數(shù)據(jù)庫等),不妨把相應(yīng)的連接和路徑信息存儲在用戶界面支持表里。還有,如果用戶界面執(zhí)行工作流之類的任務(wù)(發(fā)送郵件、打印信箋、修改記錄狀態(tài)等),那么產(chǎn)生工作流的數(shù)據(jù)也可以存放在數(shù)據(jù)庫里。角色權(quán)限管理也可以通過數(shù)據(jù)驅(qū)動來完成。事實上,如果過程是數(shù)據(jù)驅(qū)動的,你就可以把相當(dāng)大的責(zé)任推給用戶,由用戶來維護(hù)自己的工作流過程。
3) 考慮各種變化
在設(shè)計數(shù)據(jù)庫的時候考慮到哪些數(shù)據(jù)字段將來可能會發(fā)生變更。 舉例,姓氏就是如此(注意是西方人的姓氏,比如女性結(jié)婚后從夫姓等)。所以,在建立系統(tǒng)存儲客戶信息時,在單獨的一個數(shù)據(jù)表里存儲姓氏字段,而且還附加起始日和終止日等字段,這樣就可以跟蹤這一數(shù)據(jù)條目的變化。
字段設(shè)計原則
4) 每個表中都應(yīng)該添加的3 個有用的字段
??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) 對地址和電話采用多個字段
描述街道地址就短短一行記錄是不夠的。Address_Line1、Address_Line2 和Address_Line3 可以提供更大的靈活性。還有,電話號碼和郵件地址最好擁有自己的數(shù)據(jù)表,其間具有自身的類型和標(biāo)記類別。
6) 使用角色實體定義屬于某類別的列
在需要對屬于特定類別或者具有特定角色的事物做定義時,可以用角色實體來創(chuàng)建特定的時間關(guān)聯(lián)關(guān)系,從而可以實現(xiàn)自我文檔化。
舉例:用PERSON 實體和PERSON_TYPE 實體來描述人員。比方說,當(dāng)John Smith, Engineer 提升為John Smith, Director 乃至最后爬到John Smith, CIO 的高位,而所有你要做的不過是改變兩個表PERSON 和PERSON_TYPE 之間關(guān)系的鍵值,同時增加一個日期/時間字段來知道變化是何時發(fā)生的。這樣,你的PERSON_TYPE 表就包含了所有PERSON 的可能類型,比如Associate、Engineer、Director、CIO 或者CEO 等。還有個替代辦法就是改變PERSON 記錄來反映新頭銜的變化,不過這樣一來在時間上無法跟蹤個人所處位置的具體時間。
7) 選擇數(shù)字類型和文本類型盡量充足
在SQL 中使用smallint 和tinyint 類型要特別小心。比如,假如想看看月銷售總額,總額字段類型是smallint,那么,如果總額超過了$32,767 就不能進(jìn)行計算操作了。
而ID 類型的文本字段,比如客戶ID 或定單號等等都應(yīng)該設(shè)置得比一般想象更大。假設(shè)客戶ID 為10 位數(shù)長。那你應(yīng)該把數(shù)據(jù)庫表字段的長度設(shè)為12 或者13 個字符長。但這額外占據(jù)的空間卻無需將來重構(gòu)整個數(shù)據(jù)庫就可以實現(xiàn)數(shù)據(jù)庫規(guī)模的增長了。
8) 增加刪除標(biāo)記字段
在表中包含一個“刪除標(biāo)記”字段,這樣就可以把行標(biāo)記為刪除。在關(guān)系數(shù)據(jù)庫里不要單獨刪除某一行;最好采用清除數(shù)據(jù)程序而且要仔細(xì)維護(hù)索引整體性。
3. 選擇鍵和索引(數(shù)據(jù)庫邏輯設(shè)計)
鍵選擇原則:
1) 鍵設(shè)計4 原則
??為關(guān)聯(lián)字段創(chuàng)建外鍵。
??所有的鍵都必須唯一。
??避免使用復(fù)合鍵。
??外鍵總是關(guān)聯(lián)唯一的鍵字段。
2) 使用系統(tǒng)生成的主鍵
設(shè)計數(shù)據(jù)庫的時候采用系統(tǒng)生成的鍵作為主鍵,那么實際控制了數(shù)據(jù)庫的索引完整性。這樣,數(shù)據(jù)庫和非人工機制就有效地控制了對存儲數(shù)據(jù)中每一行的訪問。采用系統(tǒng)生成鍵作為主鍵還有一個優(yōu)點:當(dāng)擁有一致的鍵結(jié)構(gòu)時,找到邏輯缺陷很容易。
3) 不要用用戶的鍵(不讓主鍵具有可更新性)
在確定采用什么字段作為表的鍵的時候,可一定要小心用戶將要編輯的字段。通常的情況下不要選擇用戶可編輯的字段作為鍵。
4) 可選鍵有時可做主鍵
把可選鍵進(jìn)一步用做主鍵,可以擁有建立強大索引的能力。
索引使用原則:
索引是從數(shù)據(jù)庫中獲取數(shù)據(jù)的最高效方式之一。95%的數(shù)據(jù)庫性能問題都可以采用索引技術(shù)得到解決。
1) 邏輯主鍵使用唯一的成組索引,對系統(tǒng)鍵(作為存儲過程)采用唯一的非成組索引,對任何外鍵列采用非成組索引。考慮數(shù)據(jù)庫的空間有多大,表如何進(jìn)行訪問,還有這些訪問是否主要用作讀寫。
2) 大多數(shù)數(shù)據(jù)庫都索引自動創(chuàng)建的主鍵字段,但是可別忘了索引外鍵,它們也是經(jīng)常使用的鍵,比如運行查詢顯示主表和所有關(guān)聯(lián)表的某條記錄就用得上。
3) 不要索引memo/note 字段,不要索引大型字段(有很多字符),這樣作會讓索引占用太多的存儲空間。
4) 不要索引常用的小型表
不要為小型數(shù)據(jù)表設(shè)置任何鍵,假如它們經(jīng)常有插入和刪除操作就更別這樣作了。對這些插入和刪除操作的索引維護(hù)可能比掃描表空間消耗更多的時間。
4. 數(shù)據(jù)完整性設(shè)計(數(shù)據(jù)庫邏輯設(shè)計)
1) 完整性實現(xiàn)機制:
實體完整性:主鍵
參照完整性:
父表中刪除數(shù)據(jù):級聯(lián)刪除;受限刪除;置空值
父表中插入數(shù)據(jù):受限插入;遞歸插入
父表中更新數(shù)據(jù):級聯(lián)更新;受限更新;置空值
DBMS對參照完整性可以有兩種方法實現(xiàn):外鍵實現(xiàn)機制(約束規(guī)則)和觸發(fā)器實現(xiàn)機制
用戶定義完整性:
NOT NULL;CHECK;觸發(fā)器
2) 用約束而非商務(wù)規(guī)則強制數(shù)據(jù)完整性
采用數(shù)據(jù)庫系統(tǒng)實現(xiàn)數(shù)據(jù)的完整性。這不但包括通過標(biāo)準(zhǔn)化實現(xiàn)的完整性而且還包括數(shù)據(jù)的功能性。在寫數(shù)據(jù)的時候還可以增加觸發(fā)器來保證數(shù)據(jù)的正確性。不要依賴于商務(wù)層保證數(shù)據(jù)完整性;它不能保證表之間(外鍵)的完整性所以不能強加于其他完整性規(guī)則之上。
3) 強制指示完整性
在有害數(shù)據(jù)進(jìn)入數(shù)據(jù)庫之前將其剔除。激活數(shù)據(jù)庫系統(tǒng)的指示完整性特性。這樣可以保持?jǐn)?shù)據(jù)的清潔而能迫使開發(fā)人員投入更多的時間處理錯誤條件。
4) 使用查找控制數(shù)據(jù)完整性
控制數(shù)據(jù)完整性的最佳方式就是限制用戶的選擇。只要有可能都應(yīng)該提供給用戶一個清晰的價值列表供其選擇。這樣將減少鍵入代碼的錯誤和誤解同時提供數(shù)據(jù)的一致性。某些公共數(shù)據(jù)特別適合查找:國家代碼、狀態(tài)代碼等。
5) 采用視圖
為了在數(shù)據(jù)庫和應(yīng)用程序代碼之間提供另一層抽象,可以為應(yīng)用程序建立專門的視圖而不必非要應(yīng)用程序直接訪問數(shù)據(jù)表。這樣做還等于在處理數(shù)據(jù)庫變更時給你提供了更多的自由。
5. 其他設(shè)計技巧
1) 避免使用觸發(fā)器
觸發(fā)器的功能通??梢杂闷渌绞綄崿F(xiàn)。在調(diào)試程序時觸發(fā)器可能成為干擾。假如你確實需要采用觸發(fā)器,你最好集中對它文檔化。
2) 使用常用英語(或者其他任何語言)而不要使用編碼
在創(chuàng)建下拉菜單、列表、報表時最好按照英語名排序。假如需要編碼,可以在編碼旁附上用戶知道的英語。
3) 保存常用信息
讓一個表專門存放一般數(shù)據(jù)庫信息非常有用。在這個表里存放數(shù)據(jù)庫當(dāng)前版本、最近檢查/修復(fù)(對Access)、關(guān)聯(lián)設(shè)計文檔的名稱、客戶等信息。這樣可以實現(xiàn)一種簡單機制跟蹤數(shù)據(jù)庫,當(dāng)客戶抱怨他們的數(shù)據(jù)庫沒有達(dá)到希望的要求而與你聯(lián)系時,這樣做對非客戶機/服務(wù)器環(huán)境特別有用。
4) 包含版本機制
在數(shù)據(jù)庫中引入版本控制機制來確定使用中的數(shù)據(jù)庫的版本。時間一長,用戶的需求總是會改變的。最終可能會要求修改數(shù)據(jù)庫結(jié)構(gòu)。把版本信息直接存放到數(shù)據(jù)庫中更為方便。
5) 編制文檔
對所有的快捷方式、命名規(guī)范、限制和函數(shù)都要編制文檔。
采用給表、列、觸發(fā)器等加注釋的數(shù)據(jù)庫工具。對開發(fā)、支持和跟蹤修改非常有用。
對數(shù)據(jù)庫文檔化,或者在數(shù)據(jù)庫自身的內(nèi)部或者單獨建立文檔。這樣,當(dāng)過了一年多時間后再回過頭來做第2 個版本,犯錯的機會將大大減少。
6) 測試、測試、反復(fù)測試
建立或者修訂數(shù)據(jù)庫之后,必須用用戶新輸入的數(shù)據(jù)測試數(shù)據(jù)字段。最重要的是,讓用戶進(jìn)行測試并且同用戶一道保證選擇的數(shù)據(jù)類型滿足商業(yè)要求。測試需要在把新數(shù)據(jù)庫投入實際服務(wù)之前完成。
7) 檢查設(shè)計
在開發(fā)期間檢查數(shù)據(jù)庫設(shè)計的常用技術(shù)是通過其所支持的應(yīng)用程序原型檢查數(shù)據(jù)庫。換句話說,針對每一種最終表達(dá)數(shù)據(jù)的原型應(yīng)用,保證你檢查了數(shù)據(jù)模型并且查看如何取出數(shù)據(jù)。
三、數(shù)據(jù)庫命名規(guī)范
1. 實體(表)的命名
1) 表以名詞或名詞短語命名,確定表名是采用復(fù)數(shù)還是單數(shù)形式,此外給表的別名定義簡單規(guī)則(比方說,如果表名是一個單詞,別名就取單詞的前4 個字母;如果表名是兩個單詞,就各取兩個單詞的前兩個字母組成4 個字母長的別名;如果表的名字由3 個單詞組成,從頭兩個單詞中各取一個然后從最后一個單詞中再取出兩個字母,結(jié)果還是組成4 字母長的別名,其余依次類推)
對工作用表來說,表名可以加上前綴WORK_ 后面附上采用該表的應(yīng)用程序的名字。在命名過程當(dāng)中,根據(jù)語義拼湊縮寫即可。注意,由于ORCLE會將字段名稱統(tǒng)一成大寫或者小寫中的一種,所以要求加上下劃線。
舉例:
定義的縮寫 Sales: Sal 銷售;
Order: Ord 訂單;
Detail: Dtl 明細(xì);
則銷售訂單明細(xì)表命名為:Sal_Ord_Dtl;
2) 如果表或者是字段的名稱僅有一個單詞,那么建議不使用縮寫,而是用完整的單詞。
舉例:
定義的縮寫 Material Ma 物品;
物品表名為:Material, 而不是 Ma.
但是字段物品編碼則是:Ma_ID;而不是Material_ID
3) 所有的存儲值列表的表前面加上前綴Z
目的是將這些值列表類排序在數(shù)據(jù)庫最后。
4) 所有的冗余類的命名(主要是累計表)前面加上前綴X
冗余類是為了提高數(shù)據(jù)庫效率,非規(guī)范化數(shù)據(jù)庫的時候加入的字段或者表
5) 關(guān)聯(lián)類通過用下劃線連接兩個基本類之后,再加前綴R的方式命名,后面按照字母順序羅列兩個表名或者表名的縮寫。
關(guān)聯(lián)表用于保存多對多關(guān)系。
如果被關(guān)聯(lián)的表名大于10個字母,必須將原來的表名的進(jìn)行縮寫。如果沒有其他原因,建議都使用縮寫。
舉例:表Object與自身存在多對多的關(guān)系,則保存多對多關(guān)系的表命名為:R_Object;
表 Depart和Employee;存在多對多的關(guān)系;則關(guān)聯(lián)表命名為R_Dept_Emp
2. 屬性(列)的命名
1) 采用有意義的列名,表內(nèi)的列要針對鍵采用一整套設(shè)計規(guī)則。每一個表都將有一個自動ID作為主健,邏輯上的主健作為第一組候選主健來定義,如果是數(shù)據(jù)庫自動生成的編碼,統(tǒng)一命名為:ID;如果是自定義的邏輯上的編碼則用縮寫加“ID”的方法命名。如果鍵是數(shù)字類型,你可以用_NO 作為后綴;如果是字符類型則可以采用_CODE 后綴。對列名應(yīng)該采用標(biāo)準(zhǔn)的前綴和后綴。
舉例:銷售訂單的編號字段命名:Sal_Ord_ID;如果還存在一個數(shù)據(jù)庫生成的自動編號,則命名為:ID。
2) 所有的屬性加上有關(guān)類型的后綴,注意,如果還需要其它的后綴,都放在類型后綴之前。
注: 數(shù)據(jù)類型是文本的字段,類型后綴TX可以不寫。有些類型比較明顯的字段,可以不寫類型后綴。
3) 采用前綴命名
給每個表的列名都采用統(tǒng)一的前綴,那么在編寫SQL表達(dá)式的時候會得到大大的簡化。這樣做也確實有缺點,比如破壞了自動表連接工具的作用,后者把公共列名同某些數(shù)據(jù)庫聯(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. 存儲過程名
存儲過程應(yīng)以'UP_'開頭,和系統(tǒng)的存儲過程區(qū)分,后續(xù)部分主要以動賓形式構(gòu)成,并用下劃線分割各個組成部分。如增加代理商的帳戶的存儲過程為'UP_Ins_Agent_Account'。
6. 變量名
變量名采用小寫,若屬于詞組形式,用下劃線分隔每個單詞,如@my_err_no。
7. 命名中其他注意事項
1) 以上命名都不得超過30個字符的系統(tǒng)限制。變量名的長度限制為29(不包括標(biāo)識字符@)。
2) 數(shù)據(jù)對象、變量的命名都采用英文字符,禁止使用中文命名。絕對不要在對象名的字符之間留空格。
3) 小心保留詞,要保證你的字段名沒有和保留詞、數(shù)據(jù)庫系統(tǒng)或者常用訪問方法沖突
5) 保持字段名和類型的一致性,在命名字段并為其指定數(shù)據(jù)類型的時候一定要保證一致性。假如數(shù)據(jù)類型在一個表里是整數(shù),那在另一個表里可就別變成字符型了。
首先是選題,一般老師都會提供若干個選題給你選,其中必然包括幾個“XX系統(tǒng)的設(shè)計與開發(fā)”,這樣的選題就是符合我們前面的假設(shè)和預(yù)想的。盤他!假設(shè)我現(xiàn)在選了一個題目是“基于SSM的XX網(wǎng)上商城的設(shè)計與開發(fā)”。
選完題目就面臨著一個問題:是先做開發(fā)還是先寫文章,或者是一邊寫一邊開發(fā)。我的建議是一邊寫一邊開發(fā)。原因是:開發(fā)的過程是需要寫一些文案的,比如需求分析、數(shù)據(jù)庫的表結(jié)構(gòu)的關(guān)系、整個系統(tǒng)的交互邏輯等等。而這些文案是可以出現(xiàn)在我們的論文當(dāng)中的。
那接下來就說一下如何開發(fā)和寫文論,當(dāng)然某些開發(fā)過程我只能粗略的說一下。
1.摘要:
這是所有論文的第一個小title,說他惡心有時候也惡心,說他簡單也是蠻簡單的。那么這一部分究竟是要寫什么的?由于這一部分需要展現(xiàn)出做這個系統(tǒng)的必要性、開發(fā)這個系統(tǒng)的實現(xiàn)方式、系統(tǒng)的功能和系統(tǒng)的作用。所以可以這樣寫:
隨著中國經(jīng)濟的高速發(fā)展以及網(wǎng)絡(luò)技術(shù)的普及,互聯(lián)網(wǎng)的技術(shù)得到全面的發(fā)展,中國的各行各業(yè)都在互聯(lián)網(wǎng)的影響下發(fā)生了變革?;ヂ?lián)網(wǎng)的快速發(fā)展催生了許多產(chǎn)業(yè),其中最具代表性的便是電子商務(wù),電子商務(wù)使得企業(yè)和客戶的營銷關(guān)系由實體店銷售準(zhǔn)換為網(wǎng)絡(luò)電子商務(wù)營銷。馬云曾說:“讓天底下沒有難做的生意”,越來越多的店家選擇在網(wǎng)上開店,使得交易不再限制于天南地北,同時也大大降低了店家的經(jīng)營成本,在提高收益的同時,也方便了客戶,本課題正式在這種背景下應(yīng)運而生。
本課題介紹了“基于SSM的XX網(wǎng)上商城”的開發(fā)環(huán)境、需求分析、界面設(shè)計和數(shù)據(jù)庫設(shè)計以及涉及到的框架。
本系統(tǒng)采用了B/S架構(gòu),使用了Java、HTML、JS等語言,使用了主流的后臺開發(fā)框架SSM(spring+springMVC+Mybatis),以及采用了開源的輕量級數(shù)據(jù)庫Mysql進(jìn)行開發(fā),為網(wǎng)絡(luò)商城提供了前端展示和后臺管理的模塊,實現(xiàn)了注冊、登錄以及購物等主要功能,為消費者提供了便捷快速的購物體驗,以及為提高了店家的銷售效率。
關(guān)鍵字:網(wǎng)上商城,SSM,Java,HTML,JS,MySQL
(關(guān)鍵字一般就是把摘要中提及到的關(guān)鍵性技術(shù)提取出來,讓閱讀者一目了然,知道哪些是重點)
Abstract:......
(英文摘要建議谷歌翻譯,然后把明顯錯誤的地方修改一下即可)
2.第一章:引言
這一部分也是比虛的,其實隨便扯一扯就可以了,一般包含以下幾部分1.背景2.研究內(nèi)容。其中背景主要講一些關(guān)于社會發(fā)展的趨勢導(dǎo)致了一些什么問題,而這些問題又應(yīng)該如何去解決,多說幾句,寫到兩三百字即可。研究內(nèi)容就是針對上述的背景我們?nèi)绾芜M(jìn)行改進(jìn)。細(xì)心的同學(xué)可能會說,感覺跟摘要有些重復(fù)。是的!這兩部分內(nèi)容其實是挺重復(fù)的,但是沒關(guān)系,不過不要使用完完全全一樣的話去描述,因為最后論文查重的時候會對文章自引用進(jìn)行查重的。這一部分也是三五百字即可。
3.第二章:系統(tǒng)的開發(fā)技術(shù)介紹
這一部分是需要我們在正式開發(fā)之前做好的技術(shù)調(diào)研,然后對這一部分的技術(shù)進(jìn)行詳細(xì)的介紹。這一部分我不可能細(xì)講,因為內(nèi)容太多了,而且對于不同的項目有不同的內(nèi)容,在查閱資料的過程也是提升技術(shù)的一個重要的環(huán)節(jié),你可以真真切切的了解到開發(fā)一個工程是需要哪方面的知識,因此我就對我所選的這個課題應(yīng)該使用到的技術(shù)棧進(jìn)行一下介紹,也算是拋磚引玉,各位同學(xué)可以根據(jù)自己的實際情況進(jìn)行撰寫。
開發(fā)不同的系統(tǒng)雖然涉及到的業(yè)務(wù)邏輯不同,處理方式也千差萬別,但是本質(zhì)上都是一樣的,都是前端界面通過服務(wù)器跟數(shù)據(jù)庫進(jìn)行數(shù)據(jù)交互的一個過程,涉及到的內(nèi)容也無非就是前端、后臺和服務(wù)器。但是有一個需要注意的點,就是不要把HTML、JAVA等使用的語言介紹也給堆在這里,老師沒細(xì)看還好,細(xì)看還是會顯得太水字?jǐn)?shù)了,記住,寫工程性的課題不怕沒字?jǐn)?shù)。那問題來了,語言介紹不給寫那應(yīng)該些什么呢?應(yīng)該寫涉及到的框架、使用的工具。這些就夠了,隨隨便便就幾千字了。下面舉例簡單說明一下。
a. 前端
強調(diào)一下,不要把HTML、CSS等一下前端的規(guī)范展開來寫,可以輕描淡寫,但篇幅不能過多。這里可以寫前端框架的使用,比如使用npm管理包(可以介紹一下npm以及在工程中的使用)、vue的使用(同樣可以介紹vue框架以及應(yīng)用)、element(element以及使用他的好處)等等。也希望同學(xué)在做畢設(shè)的過程中要真的去了解這些技術(shù)并且去使用它,相信我,看完再去用你的技術(shù)會有質(zhì)的飛躍。
b. 后臺
這一部分是重點,對于本課題來說,標(biāo)題就寫了是基于SSM的。對于這個java框架并不熟悉的同學(xué)來說建議先去查一下資料,而且很多同學(xué)會有疑問,使用技術(shù)框架的目的就是為了讓開發(fā)更加的便捷和快速,但是為什么我們自己在開發(fā)的過程中會感覺好像變得更加復(fù)雜?很負(fù)責(zé)任的告訴你,是正常的。因為框架不僅會幫我們封裝好一些常用的方法,而且會考慮到更新迭代以及代碼可讀性等等的一系列的問題,某些規(guī)定和配置我們之所以沒有感受到他的好處是因為這種校園內(nèi)的開發(fā)并不涉及生產(chǎn)問題,也不會有很多的更新迭代,更加不會考慮到代碼的可讀性。例如spring的工廠,一開始使用的時候很多同學(xué)會覺得為什么我new一個類的時候還要去改配置文件,直接new不香嗎?直接new是很香,但是你考慮到真正去工作的時候,假設(shè)你要改類的一些關(guān)系的時候,還要去改代碼,當(dāng)工程一大,代碼去哪里找呢?一個一個文件看嗎?顯然是非常不可取的,效率非常低,這個時候配置文件的優(yōu)勢就發(fā)揮出來了,直接修改配置文件,不需要更改代碼,耦合性也大大的降低。好像跑題了,說了這么多就告訴同學(xué)們,要沉住氣,理解框架這樣設(shè)計背后的原因,對大家自身技術(shù)的提高非常的有幫助!
那這一部分我們就可以介紹spring(包括spring的IOC、spring的工廠、spring的AOP等等,并且可以在論文中強調(diào)如何應(yīng)用到我們的系統(tǒng)當(dāng)中)、springMVC(這一部分可以講解srpingMVC作為一個連接前端和數(shù)據(jù)庫的工具在實際工作過程中的具體流程,也可以講述springMVC的分層的概念以及如何應(yīng)用)、Mybatis(包括跟JDBC的關(guān)系、mybatis依賴的配置、使用到的接口、動態(tài)代理、一級緩存和二級緩存以及延遲加載等等的一些技術(shù)問題)
c. 服務(wù)器和數(shù)據(jù)庫
這一部分可以介紹一下用來搭建服務(wù)器的工具和所使用的數(shù)據(jù)庫。假設(shè)你是使用了云服務(wù)器來搭建了,可以詳細(xì)介紹一下云服務(wù)器的搭建過程包括防火墻、端口等等內(nèi)容。一般服務(wù)器使用tomcat進(jìn)行搭建,可以把tomcat介紹一下并且介紹一下tomcat是如何監(jiān)聽和解析用戶請求的具體流程。
一般小型的項目采用MySQL作為數(shù)據(jù)庫,可以詳細(xì)說一下選擇MySQL的原因,比如相對于Oracle的好處??梢越榻B一下MySQL數(shù)據(jù)庫的一些特點包括分頁、是否支持事務(wù)等等。
4.第三章:需求分析
這一部分是針對具體的業(yè)務(wù)場景來分析需要開發(fā)哪些功能,這一部分可以讓你感受一下產(chǎn)品經(jīng)理的職責(zé),只不過不需要跟程序員對接,因為你自己就是程序員哈哈。一般來說分成兩部分就可以了,一部分是對于前端的業(yè)務(wù)流程,另一部分就是后臺服務(wù)器的業(yè)務(wù)流程,可以使用一些軟件來繪畫流程圖,想圖個方便可以直接使用word自帶的圖形進(jìn)行編寫,也不至于難看,就比較簡約。想做的好看點的話個人推薦使用xmind,非常簡單,可以快速做出美觀的流程圖。如果沒有什么思路,那前端就按照著使用者的邏輯去寫,比如用戶需要注冊、登錄、找回密碼、購物、退貨等操作,那后端就對應(yīng)著這些前端邏輯需要有相應(yīng)的業(yè)務(wù)處理。個人感覺這一部分比較好寫,就不再贅述。
5.第四章:系統(tǒng)的設(shè)計和實現(xiàn)
這一部分可以挑選一些有代表性的功能出來細(xì)講,有些同學(xué)可能會有疑問,論文可不可以貼代碼呢?答案是可以的。但是我個人的建議是貼偽代碼,不要把你寫的長篇大論的代碼全部放進(jìn)去,不好看而且邏輯混亂,應(yīng)該做的是把代碼抽取為偽代碼,貼代碼的目的是為了讓閱讀者清晰地讀懂你是如何實現(xiàn)這個功能的,他并不會在意你的語法你的命名。下面列舉若干個可以寫的內(nèi)容,并不限于此。
a. SSM框架的整合。如何使用Spring來整合并且管理SpringMVC和Mybatis.
b. 客戶登錄狀態(tài)保存的實現(xiàn)。這一部分可能會涉及到cookies,sessions以及http報文解析等等,都可以詳解。
c. 后臺商品管理的功能。這一部分可以根據(jù)管理員的后臺管理功能進(jìn)行描寫。
d. 商品搜索功能??梢陨婕暗綌?shù)據(jù)庫的模糊搜索。
e. 數(shù)據(jù)庫表格的設(shè)計。可以體現(xiàn)數(shù)據(jù)庫表格設(shè)計的時候如何遵守三范式。
f. 可以寫在開發(fā)過程中遇到的一些疑難雜癥。
g. 可以寫開發(fā)過程中使用到的一些比較具有亮點的語言特性。比如java的多線程、lambda表達(dá)式。又比如實現(xiàn)注冊功能的時候使用的正則表達(dá)式。
……
等等數(shù)不勝數(shù)。
6.第五章:運行結(jié)果
這一部分非常好寫了。截取一些關(guān)于你的系統(tǒng)的界面并且介紹一下功能,盡量說詳細(xì)點,就ok了。
7.第六章:總結(jié)以及展望
這一部分也是比較水的一部分,但是也希望同學(xué)們認(rèn)真寫一寫??梢詫懸幌履汩_發(fā)這個項目的過程中學(xué)習(xí)到了什么,可以是XX技術(shù),也可以是艱苦奮斗的精神……。展望可以寫有望發(fā)展成另外一個淘寶……開玩笑開玩笑,總之劈里啪啦湊個幾百字即可。
8.參考文獻(xiàn)
把你開發(fā)過程中參考過的文章、論文貼進(jìn)去之后,往往會發(fā)現(xiàn)參考文獻(xiàn)不夠,太少了!那怎么辦呢?那就貼一些關(guān)于使用的技術(shù)的文章或者參考手冊咯,雖然大部分是沒看過的,但是還是希望大家可以多少看一看(正義之氣躍然紙上)。去知網(wǎng)查找參考文章然后添加到你的參考文獻(xiàn)是非常方便的,只需要找到對應(yīng)的文章并且選擇“引用”功能,即可自動生成引用的文字,直接復(fù)制到你的論文中。
9.致謝
第一步,感謝你的導(dǎo)師,感謝你的院領(lǐng)導(dǎo),感謝你的校領(lǐng)導(dǎo)。說的好聽后可能答辯的時候不會太為難你……然后你要感謝你的家人你的舍友你的朋友或者是你家的狗(開玩笑),都可以的,這一部分又輕輕松松兩百字。
至此,一篇計算機論文就寫完了,是不是覺得挺簡單的呢?以上內(nèi)容皆由學(xué)術(shù)堂提供整理。
CHAR 0-255字節(jié) 定長字符串 VARCHAR 0-255字節(jié) 變長字符串 TINYBLOB 0-255字節(jié) 不超過 255 個字符的二進(jìn)制字符串 TINYTEXT 0-255字節(jié) 短文本字符串 BLOB 0-65 535字節(jié) 二進(jìn)制形式的長文本數(shù)據(jù) TEXT 0-65 535字節(jié) 長文本數(shù)據(jù) MEDIUMBLOB 0-16 777 215字節(jié) 二進(jìn)制形式的中等長度文本數(shù)據(jù) MEDIUMTEXT 0-16 777 215字節(jié) 中等長度文本數(shù)據(jù) LOGNGBLOB 0-4 294 967 295字節(jié) 二進(jìn)制形式的極大文本數(shù)據(jù) LONGTEXT 0-4 294 967 295字節(jié) 極大文本數(shù)據(jù)
標(biāo)題名稱:MySQL論文怎么寫 2021中秋節(jié)要調(diào)休嗎
鏈接分享:http://chinadenli.net/article38/dogidpp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、用戶體驗、手機網(wǎng)站建設(shè)、全網(wǎng)營銷推廣、App開發(fā)、定制開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)