作為一個著重研究信息系統(tǒng)開發(fā)、應(yīng)用的專業(yè),計算機畢業(yè)論文的寫作應(yīng)該更貼合實際出來,可能有很多剛拿到題目的學(xué)生不知道改如何著手,下面我們就來了解一下計算機畢業(yè)論文怎么寫?
在永安等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都做網(wǎng)站、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需制作,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),網(wǎng)絡(luò)營銷推廣,外貿(mào)網(wǎng)站制作,永安網(wǎng)站建設(shè)費用合理。
一、計算機畢業(yè)論文的寫作方法
1、前言部分
前言部分也常用"引論"、"概論"、"問題背景"等做標題,在這部分中,主要介紹論文的選題。
首先要闡明選題的背景和選題的意義。選題需強調(diào)實際背景,說明在計算機研究中或部門信息化建設(shè)、企業(yè)管理現(xiàn)代化等工作中引發(fā)該問題的原因,問題出現(xiàn)的環(huán)境和條件,解決該問題后能起什么作用。結(jié)合問題背景的闡述,要使讀者感受到此選題確有實用價值和學(xué)術(shù)價值,因而有研究和開發(fā)的必要性。
前言部分常起到畫龍點睛的作用。選題實際又有新意,表明作者的研究方向正確,設(shè)計開發(fā)工作有價值。對一篇論文來說,前言寫好了,就會吸引讀者,使他們對作者的選題感興趣,愿意進一步了解作者的工作成果。
?
2、綜述部分
任何一個課題的研究或開發(fā)都是有學(xué)科基礎(chǔ)或技術(shù)基礎(chǔ)的。綜述部分主要闡述選題在相應(yīng)學(xué)科領(lǐng)域中的發(fā)展進程和研究方向,特別是近年來的發(fā)展趨勢和最新成果。通過與中外研究成果的比較和評論,說明自己的選題是符合當前的研究方向并有所進展,或采用了當前的最新技術(shù)并有所改進,目的是使讀者進一步了解選題的意義。
綜述部分能反映出畢業(yè)設(shè)計學(xué)生多方面的能力。首先是結(jié)合課題任務(wù)獨立查閱中外文獻資料的能力,通過查閱文獻資料,收集各種信息,了解同行的研究水平,在工作和論文中有效地運用文獻,這不僅能避免簡單的重復(fù)研究,而且也能使論文工作有一個高起點。
其次,還能反映出綜合分析的能力。從大量的文獻中找到可以借鑒和參考的信息,這不僅要有一定的專業(yè)知識水平,還要有一定的綜合能力。對同行研究成果是否能抓住要點,優(yōu)缺點的評述是否符合實際,恰到好處,這和一個人的分析理解能力是有關(guān)的。
值得注意的是,要做好一篇畢業(yè)論文,必須閱讀一定量(2~3篇)的近期外文資料,這不僅反映自己的外文閱讀能力,而且有助于體現(xiàn)論文的先進性。
3、方案論證
在明確了所要解決的問題和課題綜述后,很自然地就要提出自己解決問題的思路和方案。在寫作方法上,一是要通過比較,顯示自己方案的價值,二是讓讀者了解方案的獨到之處或有創(chuàng)新點的思路、算法和關(guān)鍵技術(shù)。
在與文獻資料中的方案進行比較時,首先要闡述自己的設(shè)計方案,說明為什么要選擇或設(shè)計這樣的方案,前面評述的優(yōu)點在此方案中如何體現(xiàn),不足之處又是如何得到了克服,最后完成的工作能達到什么性能水平,有什么創(chuàng)新之處(或有新意)。如果自己的題目是總方案的一部分,一定要明確說明自己承擔的部分,以及對整個任務(wù)的貢獻。
4、論文主體
在這部分中,要將整個研究開發(fā)工作的內(nèi)容,包括理論分析、總體設(shè)計、模塊劃分、實現(xiàn)方法等進行詳細的論述。論文主體部分要占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è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)所要求達到的功能逐一進行測試。性能測試一般是在系統(tǒng)(子系統(tǒng))的運行狀態(tài)下,記錄實例運行的數(shù)據(jù),然后,歸納和計算這些數(shù)據(jù),以此來分析系統(tǒng)運行的性能。
測試實例可以自己設(shè)計編寫,也可以選擇學(xué)科領(lǐng)域內(nèi)公認的、有一定權(quán)威性的測試實例或測試集。原則是通過所選擇(設(shè)計)的實例的運行,既能準確反映系統(tǒng)運行的功能和性能,與同類系統(tǒng)又有可比性。只有這樣,論文最后為自己工作所做的結(jié)論才有說服力。
6、結(jié)束語
這一節(jié)篇幅不大,首先對整個論文工作做一個簡單小結(jié),然后將自己在研究開發(fā)工作中所做的貢獻,或獨立研究的成果列舉出來,再對自己工作的進展、水平做一個實事求是的評論。但在用"首次提出"、"重大突破"、"重要價值"等自我評語時要慎重。
7、后記
在后記中,主要表達對導(dǎo)師和其他有關(guān)教師和同學(xué)的感謝之意。對此,仍要實事求是,過分的頌揚反而會帶來消極影響。這一節(jié)也可用"致謝"做標題。
8、參考文獻
中外文的參考文獻應(yīng)按照規(guī)范列舉在論文最后。這一部分的編寫反映作者的學(xué)術(shù)作風。編寫參考文獻要注意:(1)要嚴格按照規(guī)范編寫,特別是外文文獻,不要漏寫、錯寫;(2)論文內(nèi)容和參考文獻要前后對應(yīng),正文中凡引用參考文獻的地方應(yīng)加注;(3)列出的文獻資料應(yīng)與論文課題相關(guān),無關(guān)的文獻只會使讀者感到作者的研究目標很分散;(4)選擇的參考文獻應(yīng)主要是近期的。
二、計算機寫作注意事項
1、設(shè)計(論文)題目:按照小題目。封面XXXXX學(xué)院畢業(yè)設(shè)計(論文)、 屆 分院(系)
2、摘要:不要主語,英文中無法表達時可用被動語態(tài)
3、關(guān)鍵詞:體現(xiàn)設(shè)計(論文)主要工作的詞語
4、目錄:自動生成,1.1.1的格式,最多到1.1.1.1 5、正文中文獻引用要客觀,別人的成果要說明,不要據(jù)為己有;自己的成果要突出。不清楚的圖必須修改(可用word畫或者AutoCAD畫),表格盡量采用三線表
6、參考文獻:至少要有兩篇英文文獻
7、致謝(不是致辭)
8、附錄(若多于一個附錄,可用附錄一、附錄二,……)
9、各部分格式要求,嚴格按照畢業(yè)設(shè)計手冊執(zhí)行
三、計算機論文編輯技巧
1、文檔結(jié)構(gòu)圖的妙用 格式修改時可先將全文設(shè)置為正文格式(新羅馬與宋體的博弈),然后將三級標題以上標題按照三級標題提出來,再將二級標題以上標題按照二級標題提出來,最后將一級標題提出來。提出標題時注意使用大綱級別。 提出大綱級別后,可用文檔結(jié)構(gòu)圖輕松導(dǎo)航文檔。還可自動生成目錄(插入-引用-索引和目錄-目錄)。
2、圖的裁剪與組合(建議采用浮于文字上方的方式)、文本框的妙用、公式的編輯(變量用斜體、下標用的i、j、k用斜體,其余用正體。公式中出現(xiàn)漢字怎么辦?用拼音加加輸入法輸入漢字)
3、表格的編輯
4、上下標的使用(自定義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特點和處理的需要,進行物理存儲安排,設(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)查表請用戶填寫、查閱記錄。
分析和表達用戶需求的方法主要包括自頂向下和自底向上兩類方法。自頂向下的結(jié)構(gòu)化分析方法(Structured Analysis,簡稱SA方法)從最上層的系統(tǒng)組織機構(gòu)入手,采用逐層分解的方式分析系統(tǒng),并把每一層用數(shù)據(jù)流圖和數(shù)據(jù)字典描述。
數(shù)據(jù)流圖表達了數(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è)計階段
通過對用戶需求進行綜合、歸納與抽象,形成一個獨立于具體DBMS的概念模型,可以用E-R圖表示。
概念模型用于信息世界的建模。概念模型不依賴于某一個DBMS支持的數(shù)據(jù)模型。概念模型可以轉(zhuǎn)換為計算機上某一DBMS支持的特定數(shù)據(jù)模型。
概念模型特點:
(1) 具有較強的語義表達能力,能夠方便、直接地表達應(yīng)用中的各種語義知識。
(2) 應(yīng)該簡單、清晰、易于用戶理解,是用戶與數(shù)據(jù)庫設(shè)計人員之間進行交流的語言。
概念模型設(shè)計的一種常用方法為IDEF1X方法,它就是把實體-聯(lián)系方法應(yīng)用到語義數(shù)據(jù)模型中的一種語義模型化技術(shù),用于建立系統(tǒng)信息模型。
使用IDEF1X方法創(chuàng)建E-R模型的步驟如下所示:
2.1 第零步——初始化工程
這個階段的任務(wù)是從目的描述和范圍描述開始,確定建模目標,開發(fā)建模計劃,組織建模隊伍,收集源材料,制定約束和規(guī)范。收集源材料是這階段的重點。通過調(diào)查和觀察結(jié)果,業(yè)務(wù)流程,原有系統(tǒng)的輸入輸出,各種報表,收集原始數(shù)據(jù),形成了基本數(shù)據(jù)資料表。
2.2 第一步——定義實體
實體集成員都有一個共同的特征和屬性集,可以從收集的源材料——基本數(shù)據(jù)資料表中直接或間接標識出大部分實體。根據(jù)源材料名字表中表示物的術(shù)語以及具有“代碼”結(jié)尾的術(shù)語,如客戶代碼、代理商代碼、產(chǎn)品代碼等將其名詞部分代表的實體標識出來,從而初步找出潛在的實體,形成初步實體表。
2.3 第二步——定義聯(lián)系
IDEF1X模型中只允許二元聯(lián)系,n元聯(lián)系必須定義為n個二元聯(lián)系。根據(jù)實際的業(yè)務(wù)需求和規(guī)則,使用實體聯(lián)系矩陣來標識實體間的二元關(guān)系,然后根據(jù)實際情況確定出連接關(guān)系的勢、關(guān)系名和說明,確定關(guān)系類型,是標識關(guān)系、非標識關(guān)系(強制的或可選的)還是非確定關(guān)系、分類關(guān)系。如果子實體的每個實例都需要通過和父實體的關(guān)系來標識,則為標識關(guān)系,否則為非標識關(guān)系。非標識關(guān)系中,如果每個子實體的實例都與而且只與一個父實體關(guān)聯(lián),則為強制的,否則為非強制的。如果父實體與子實體代表的是同一現(xiàn)實對象,那么它們?yōu)榉诸愱P(guān)系。
2.4 第三步——定義碼
通過引入交叉實體除去上一階段產(chǎn)生的非確定關(guān)系,然后從非交叉實體和獨立實體開始標識侯選碼屬性,以便唯一識別每個實體的實例,再從侯選碼中確定主碼。為了確定主碼和關(guān)系的有效性,通過非空規(guī)則和非多值規(guī)則來保證,即一個實體實例的一個屬性不能是空值,也不能在同一個時刻有一個以上的值。找出誤認的確定關(guān)系,將實體進一步分解,最后構(gòu)造出IDEF1X模型的鍵基視圖(KB圖)。
2.5 第四步——定義屬性
從源數(shù)據(jù)表中抽取說明性的名詞開發(fā)出屬性表,確定屬性的所有者。定義非主碼屬性,檢查屬性的非空及非多值規(guī)則。此外,還要檢查完全依賴函數(shù)規(guī)則和非傳遞依賴規(guī)則,保證一個非主碼屬性必須依賴于主碼、整個主碼、僅僅是主碼。以此得到了至少符合關(guān)系理論第三范式的改進的IDEF1X模型的全屬性視圖。
2.6 第五步——定義其他對象和規(guī)則
定義屬性的數(shù)據(jù)類型、長度、精度、非空、缺省值、約束規(guī)則等。定義觸發(fā)器、存儲過程、視圖、角色、同義詞、序列等對象信息。
3. 邏輯結(jié)構(gòu)設(shè)計階段
將概念結(jié)構(gòu)轉(zhuǎn)換為某個DBMS所支持的數(shù)據(jù)模型(例如關(guān)系模型),并對其進行優(yōu)化。設(shè)計邏輯結(jié)構(gòu)應(yīng)該選擇最適于描述與表達相應(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)系模式可合并。
為了進一步提高數(shù)據(jù)庫應(yīng)用系統(tǒng)的性能,通常以規(guī)范化理論為指導(dǎo),還應(yīng)該適當?shù)匦薷?、調(diào)整數(shù)據(jù)模型的結(jié)構(gòu),這就是數(shù)據(jù)模型的優(yōu)化。確定數(shù)據(jù)依賴。消除冗余的聯(lián)系。確定各關(guān)系模式分別屬于第幾范式。確定是否要對它們進行合并或分解。一般來說將關(guān)系分解為3NF的標準,即:
表內(nèi)的每一個值都只能被表達一次。
??表內(nèi)的每一行都應(yīng)該被唯一的標識(有唯一鍵)。
表內(nèi)不應(yīng)該存儲依賴于其他鍵的非鍵信息。
4. 數(shù)據(jù)庫物理設(shè)計階段
為邏輯數(shù)據(jù)模型選取一個最適合應(yīng)用環(huán)境的物理結(jié)構(gòu)(包括存儲結(jié)構(gòu)和存取方法)。根據(jù)DBMS特點和處理的需要,進行物理存儲安排,設(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ù)入庫,并進行試運行。 數(shù)據(jù)庫實施主要包括以下工作:用DDL定義數(shù)據(jù)庫結(jié)構(gòu)、組織數(shù)據(jù)入庫 、編制與調(diào)試應(yīng)用程序、數(shù)據(jù)庫試運行 6. 數(shù)據(jù)庫運行和維護階段
數(shù)據(jù)庫應(yīng)用系統(tǒng)經(jīng)過試運行后即可投入正式運行。在數(shù)據(jù)庫系統(tǒng)運行過程中必須不斷地對其進行評價、調(diào)整與修改。包括:數(shù)據(jù)庫的轉(zhuǎn)儲和恢復(fù)、數(shù)據(jù)庫的安全性、完整性控制、數(shù)據(jù)庫性能的監(jiā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)換為適當?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è)計出的報表、查詢和視圖(輸出)以決定為了支持這些輸出哪些是必要的表和字段。
舉例:假如客戶需要一個報表按照郵政編碼排序、分段和求和,你要保證其中包括了單獨的郵政編碼字段而不要把郵政編碼糅進地址字段里。
4) 創(chuàng)建數(shù)據(jù)字典和ER 圖表
ER 圖表和數(shù)據(jù)字典可以讓任何了解數(shù)據(jù)庫的人都明確如何從數(shù)據(jù)庫中獲得數(shù)據(jù)。ER圖對表明表之間關(guān)系很有用,而數(shù)據(jù)字典則說明了每個字段的用途以及任何可能存在的別名。對SQL 表達式的文檔化來說這是完全必要的。
5) 定義標準的對象命名規(guī)范
數(shù)據(jù)庫各種對象的命名必須規(guī)范。
2. 表和字段的設(shè)計(數(shù)據(jù)庫邏輯設(shè)計)
表設(shè)計原則
1) 標準化和規(guī)范化
數(shù)據(jù)的標準化有助于消除數(shù)據(jù)庫中的數(shù)據(jù)冗余。標準化有好幾種形式,但Third Normal Form(3NF)通常被認為在性能、擴展性和數(shù)據(jù)完整性方面達到了最好平衡。簡單來說,遵守3NF 標準的數(shù)據(jù)庫的表設(shè)計原則是:“One Fact in One Place”即某個表只包括其本身基本的屬性,當不是它們本身所具有的屬性時需進行分解。表之間的關(guān)系通過外鍵相連接。它具有以下特點:有一組表專門存放通過鍵連接起來的關(guān)聯(lián)數(shù)據(jù)。
舉例:某個存放客戶及其有關(guān)定單的3NF 數(shù)據(jù)庫就可能有兩個表:Customer 和Order。Order 表不包含定單關(guān)聯(lián)客戶的任何信息,但表內(nèi)會存放一個鍵值,該鍵指向Customer 表里包含該客戶信息的那一行。
事實上,為了效率的緣故,對表不進行標準化有時也是必要的。
2) 數(shù)據(jù)驅(qū)動
采用數(shù)據(jù)驅(qū)動而非硬編碼的方式,許多策略變更和維護都會方便得多,大大增強系統(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ū)動的,你就可以把相當大的責任推給用戶,由用戶來維護自己的工作流過程。
3) 考慮各種變化
在設(shè)計數(shù)據(jù)庫的時候考慮到哪些數(shù)據(jù)字段將來可能會發(fā)生變更。 舉例,姓氏就是如此(注意是西方人的姓氏,比如女性結(jié)婚后從夫姓等)。所以,在建立系統(tǒng)存儲客戶信息時,在單獨的一個數(shù)據(jù)表里存儲姓氏字段,而且還附加起始日和終止日等字段,這樣就可以跟蹤這一數(shù)據(jù)條目的變化。
字段設(shè)計原則
4) 每個表中都應(yīng)該添加的3 個有用的字段
??dRecordCreationDate,在VB 下默認是Now(),而在SQL Server 下默認為GETDATE()
??sRecordCreator,在SQL Server 下默認為NOT NULL DEFAULT USER
??nRecordVersion,記錄的版本標記;有助于準確說明記錄中出現(xiàn)null 數(shù)據(jù)或者丟失數(shù)據(jù)的原因
5) 對地址和電話采用多個字段
描述街道地址就短短一行記錄是不夠的。Address_Line1、Address_Line2 和Address_Line3 可以提供更大的靈活性。還有,電話號碼和郵件地址最好擁有自己的數(shù)據(jù)表,其間具有自身的類型和標記類別。
6) 使用角色實體定義屬于某類別的列
在需要對屬于特定類別或者具有特定角色的事物做定義時,可以用角色實體來創(chuàng)建特定的時間關(guān)聯(lián)關(guān)系,從而可以實現(xiàn)自我文檔化。
舉例:用PERSON 實體和PERSON_TYPE 實體來描述人員。比方說,當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 就不能進行計算操作了。
而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) 增加刪除標記字段
在表中包含一個“刪除標記”字段,這樣就可以把行標記為刪除。在關(guān)系數(shù)據(jù)庫里不要單獨刪除某一行;最好采用清除數(shù)據(jù)程序而且要仔細維護索引整體性。
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)點:當擁有一致的鍵結(jié)構(gòu)時,找到邏輯缺陷很容易。
3) 不要用用戶的鍵(不讓主鍵具有可更新性)
在確定采用什么字段作為表的鍵的時候,可一定要小心用戶將要編輯的字段。通常的情況下不要選擇用戶可編輯的字段作為鍵。
4) 可選鍵有時可做主鍵
把可選鍵進一步用做主鍵,可以擁有建立強大索引的能力。
索引使用原則:
索引是從數(shù)據(jù)庫中獲取數(shù)據(jù)的最高效方式之一。95%的數(shù)據(jù)庫性能問題都可以采用索引技術(shù)得到解決。
1) 邏輯主鍵使用唯一的成組索引,對系統(tǒng)鍵(作為存儲過程)采用唯一的非成組索引,對任何外鍵列采用非成組索引。考慮數(shù)據(jù)庫的空間有多大,表如何進行訪問,還有這些訪問是否主要用作讀寫。
2) 大多數(shù)數(shù)據(jù)庫都索引自動創(chuàng)建的主鍵字段,但是可別忘了索引外鍵,它們也是經(jīng)常使用的鍵,比如運行查詢顯示主表和所有關(guān)聯(lián)表的某條記錄就用得上。
3) 不要索引memo/note 字段,不要索引大型字段(有很多字符),這樣作會讓索引占用太多的存儲空間。
4) 不要索引常用的小型表
不要為小型數(shù)據(jù)表設(shè)置任何鍵,假如它們經(jīng)常有插入和刪除操作就更別這樣作了。對這些插入和刪除操作的索引維護可能比掃描表空間消耗更多的時間。
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ù)的完整性。這不但包括通過標準化實現(xiàn)的完整性而且還包括數(shù)據(jù)的功能性。在寫數(shù)據(jù)的時候還可以增加觸發(fā)器來保證數(shù)據(jù)的正確性。不要依賴于商務(wù)層保證數(shù)據(jù)完整性;它不能保證表之間(外鍵)的完整性所以不能強加于其他完整性規(guī)則之上。
3) 強制指示完整性
在有害數(shù)據(jù)進入數(shù)據(jù)庫之前將其剔除。激活數(shù)據(jù)庫系統(tǒng)的指示完整性特性。這樣可以保持數(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ù)庫當前版本、最近檢查/修復(fù)(對Access)、關(guān)聯(lián)設(shè)計文檔的名稱、客戶等信息。這樣可以實現(xiàn)一種簡單機制跟蹤數(shù)據(jù)庫,當客戶抱怨他們的數(shù)據(jù)庫沒有達到希望的要求而與你聯(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)部或者單獨建立文檔。這樣,當過了一年多時間后再回過頭來做第2 個版本,犯錯的機會將大大減少。
6) 測試、測試、反復(fù)測試
建立或者修訂數(shù)據(jù)庫之后,必須用用戶新輸入的數(shù)據(jù)測試數(shù)據(jù)字段。最重要的是,讓用戶進行測試并且同用戶一道保證選擇的數(shù)據(jù)類型滿足商業(yè)要求。測試需要在把新數(shù)據(jù)庫投入實際服務(wù)之前完成。
7) 檢查設(shè)計
在開發(fā)期間檢查數(shù)據(jù)庫設(shè)計的常用技術(shù)是通過其所支持的應(yīng)用程序原型檢查數(shù)據(jù)庫。換句話說,針對每一種最終表達數(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)用程序的名字。在命名過程當中,根據(jù)語義拼湊縮寫即可。注意,由于ORCLE會將字段名稱統(tǒng)一成大寫或者小寫中的一種,所以要求加上下劃線。
舉例:
定義的縮寫 Sales: Sal 銷售;
Order: Ord 訂單;
Detail: Dtl 明細;
則銷售訂單明細表命名為: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個字母,必須將原來的表名的進行縮寫。如果沒有其他原因,建議都使用縮寫。
舉例:表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)該采用標準的前綴和后綴。
舉例:銷售訂單的編號字段命名:Sal_Ord_ID;如果還存在一個數(shù)據(jù)庫生成的自動編號,則命名為:ID。
2) 所有的屬性加上有關(guān)類型的后綴,注意,如果還需要其它的后綴,都放在類型后綴之前。
注: 數(shù)據(jù)類型是文本的字段,類型后綴TX可以不寫。有些類型比較明顯的字段,可以不寫類型后綴。
3) 采用前綴命名
給每個表的列名都采用統(tǒng)一的前綴,那么在編寫SQL表達式的時候會得到大大的簡化。這樣做也確實有缺點,比如破壞了自動表連接工具的作用,后者把公共列名同某些數(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(不包括標識字符@)。
2) 數(shù)據(jù)對象、變量的命名都采用英文字符,禁止使用中文命名。絕對不要在對象名的字符之間留空格。
3) 小心保留詞,要保證你的字段名沒有和保留詞、數(shù)據(jù)庫系統(tǒng)或者常用訪問方法沖突
5) 保持字段名和類型的一致性,在命名字段并為其指定數(shù)據(jù)類型的時候一定要保證一致性。假如數(shù)據(jù)類型在一個表里是整數(shù),那在另一個表里可就別變成字符型了。
一般是在詳細設(shè)計里貼代碼的,不過不要貼太多,根據(jù)功能需求寫出主要代碼即可
編寫提綱的步驟: (一)確定論文提要,再加進材料,形成全文的概要 論文提要是內(nèi)容提綱的雛型。一般書、教學(xué)參考書都有反映全書內(nèi)容的提要,以便讀者一翻提要就知道書的大概內(nèi)容。我們寫論文也需要先寫出論文提要。在執(zhí)筆前把論文的題目和大標題、小標題列出來,再把選用的材料插進去,就形成了論文內(nèi)容的提要。 (二)原稿紙頁數(shù)的分配 寫好畢業(yè)論文的提要之后,要根據(jù)論文的內(nèi)容考慮篇幅的長短,文章的各個部分,大體上要寫多少字。如計劃寫20頁原稿紙(每頁300字)的論文,考慮序論用1頁,本論用17頁,結(jié)論用1—2頁。本論部分再進行分配,如本論共有四項,可以第一項3—4頁,第二項用4—5頁,第三項3—4頁,第四項6—7頁。有這樣的分配,便于資料的配備和安排,寫作能更有計劃。畢業(yè)論文的長短一般規(guī)定為5000—6000字,因為過短,問題很難講透,而作為畢業(yè)論文也不宜過長,這是一般大專、本科學(xué)生的理論基礎(chǔ)、實踐經(jīng)驗所決定的。 (三)編寫提綱 論文提綱可分為簡單提綱和詳細提綱兩種。簡單提綱是高度概括的,只提示論文的要點,如何展開則不涉及。這種提綱雖然簡單,但由于它是經(jīng)過深思熟慮構(gòu)成的,寫作時能順利進行。沒有這種準備,邊想邊寫很難順利地寫下去。以《關(guān)于培育和完善建筑勞動力市場的思考》為例,簡單提綱可以寫成下面這樣: 一、序論 二、本論 (一)培育建筑勞動力市場的前提條件 (二)目前建筑勞動力市場的基本現(xiàn)狀 (三)培育和完善建筑勞動力市場的對策 三、結(jié)論 詳細提綱,是把論文的主要論點和展開部分較為詳細地列出來。如果在寫作之前準備了詳細提綱,那么,執(zhí)筆時就能更順利。下面仍以《關(guān)于培育和完善建筑勞動力市場的思考》為例,介紹詳細提綱的寫法: 一、序論 1.提出中心論題; 2,說明寫作意圖。 二、本論 (一)培育建筑勞動力市場的前提條件 1.市場經(jīng)濟體制的確立,為建筑勞動力市場的產(chǎn)生創(chuàng)造了宏觀環(huán)境; 2.建筑產(chǎn)品市場的形成,對建筑勞動力市場的培育提出了現(xiàn)實的要求; 3.城鄉(xiāng)體制改革的深化,為建筑勞動力市場的形成提供了可靠的保證; 4.建筑勞動力市場的建立,是建筑行業(yè)用工特殊性的內(nèi)在要求。 (二)目前建筑勞動力市場的基本現(xiàn)狀 1.供大于求的買方市場; 2,有市無場的隱形市場; 3.易進難出的畸形市場; 4,交易無序的自發(fā)市場。 (三)培育和完善建筑勞動力市場的對策 1.統(tǒng)一思想認識,變自發(fā)交易為自覺調(diào)控; 2.加快建章立制,變無序交易為規(guī)范交易; 3.健全市場網(wǎng)絡(luò),變隱形交易為有形交易; 4.調(diào)整經(jīng)營結(jié)構(gòu),變個別流動為隊伍流動; 5,深化用工改革,變單向流動為雙向流動。 三、結(jié)論 1,概述當前的建筑勞動力市場形勢和我們的任務(wù); 2.呼應(yīng)開頭的序言。 上面所說的簡單提綱和詳細提綱都是論文的骨架和要點,選擇哪一種,要根據(jù)作者的需要。如果考慮周到,調(diào)查詳細,用簡單提綱問題不是很大;但如果考慮粗疏,調(diào)查不周,則必須用詳細提綱,否則,很難寫出合格的畢業(yè)論文??傊趧邮肿珜懏厴I(yè)’論文之前擬好提綱,寫起來就會方便得多。 三、畢業(yè)論文提綱的擬定 如何落筆擬定畢業(yè)論文提綱呢?首先要把握擬定畢業(yè)論文提綱的原則,為此要掌握如下四個方面: (一)要有全局觀念,從整體出發(fā)去檢查每一部分在論文中所占的地位和作用。看看各部分的比例分配是否恰當,篇幅的長短是否合適,每一部分能否為中心論點服務(wù)。比如有一篇論文論述企業(yè)深化改革與穩(wěn)定是辯證統(tǒng)一的,作者以浙江××市某企業(yè)為例,說只要干部在改革中以身作則,與職工同甘共苦,可以取得多數(shù)職工的理解。從全局觀念分折,我們就可以發(fā)現(xiàn)這里只講了企業(yè)如何改革才能穩(wěn)定,沒有論述通過深化改革,轉(zhuǎn)換企業(yè)經(jīng)營機制,提高了企業(yè)經(jīng)濟效益,職工收入增加,最終達到社會穩(wěn)定。 (二)從中心論點出發(fā),決定材料的取舍,把與主題無關(guān)或關(guān)系不大的材料毫不可惜地舍棄,盡管這些材料是煞費苦心費了不少勞動搜集來的。有所失,才能有所得。一塊毛料寸寸寶貴,臺不得剪裁去,也就縫制不成合身的衣服。為了成衣,必須剪裁去不需要的部分。所以,我們必須時刻牢記材料只是為形成自己論文的論點服務(wù)的,離開了這一點,無論是多少好的材料都必須舍得拋棄。 (三)要考慮各部分之間的邏輯關(guān)系。初學(xué)撰寫論文的人常犯的毛病,是論點和論據(jù)沒有必然聯(lián)系,有的只限于反復(fù)闡述論點,而缺乏切實有力的論據(jù);有的材料一大堆,論點不明確;有的各部分之間沒有形成有機的邏輯關(guān)系,這樣的畢業(yè)論文都是不合乎要求的,這樣的畢業(yè)論文是沒有說服力的。為了有說服力,必須有虛有實,有論點有例證,理論和實際相結(jié)合,論證過程有嚴密的邏輯性,擬提綱時特別要注意這一點,檢查這一點。 下面再簡單闡述一下編寫畢業(yè)論文提綱的方法: 1.先擬標題; 2.寫出總論點; 3.考慮全篇總的安排:從幾個方面,以什么順序來論述總論點,這是論文結(jié)構(gòu)的骨架; 4.大的項目安排妥當之后,再逐個考慮每個項目的下位論點,直到段一級,寫出段的論點句(即段旨); 5.依次考慮各個段的安排,把準備使用的材料按順序編碼,以便寫作時使用; 6.全面檢查,作必要的增刪。 在編寫畢業(yè)論文提綱時還要注意: 第一,編寫畢業(yè)論文提綱有兩種方法:一是標題式寫法。即用簡要的文字寫成標題,把這部分的內(nèi)容概括出來。這種寫法簡明扼要,一目了然,但只有作者自己明白。畢業(yè)論文提綱一般不能采用這種方法編寫.二是句子式寫法。即以一個能表達完整意思的句子形式把該部分內(nèi)容概括出來。這種寫法具體而明確,別人看了也能明了,但費時費力。畢業(yè)論文的提綱編寫要交與指導(dǎo)教師閱讀,所以,要求采用這種編寫方法。 第二,提綱寫好后,還有一項很重要的工作不可疏忽,這就是提綱的推敲和修改,這種推敲和修改要把握如下幾點。一是推敲題目是否恰當,是否合適;二是推敲提綱的結(jié)構(gòu)。先圍繞所要闡述的中心論點或者說明的主要議題,檢查劃分的部分、層次和段落是否可以充分說明問題,是否合乎道理;各層次、段落之間的聯(lián)系是否緊密,過渡是否自然。然后再進行客觀總體布局的檢查,再對每一層次中的論述秩序進行“微調(diào)”。 第三,畢業(yè)論文寫作一般要求提綱擬到以下層次 -------------------------------------------------------------------------------- 總論點 { { { 1.(稱段旨) (一)(稱下位論點) 2. 一、(稱上位論點) ...... (二) ...... 二、 ...... -------------------------------------------------------------------------------- (四)畢業(yè)論文的基本結(jié)構(gòu)由序論、本論、結(jié)論三大部分組成。序論、結(jié)論這兩部分在提綱中部應(yīng)比較簡略。本論則是全文的重點,是應(yīng)集中筆墨寫深寫透的部分,因此在提綱上也要列得較為詳細。本論部分至少要有兩層標準,層層深入,層層推理,以便體現(xiàn)總論點和分論點的有機結(jié)合,把論點講深講透。
希望采納
學(xué)術(shù)堂手把手得來教你如何寫出一篇計算機專業(yè)的畢業(yè)論文:
首先是選題,一般老師都會提供若干個選題給你選,其中必然包括幾個"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)在我們的論文當中的.
那接下來就說一下如何開發(fā)和寫文論,當然某些開發(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)系由實體店銷售準換為網(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進行開發(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行改進.細心的同學(xué)可能會說,感覺跟摘要有些重復(fù).是的!這兩部分內(nèi)容其實是挺重復(fù)的,但是沒關(guān)系,不過不要使用完完全全一樣的話去描述,因為最后論文查重的時候會對文章自引用進行查重的.這一部分也是三五百字即可.
3.第二章:系統(tǒng)的開發(fā)技術(shù)介紹
這一部分是需要我們在正式開發(fā)之前做好的技術(shù)調(diào)研,然后對這一部分的技術(shù)進行詳細的介紹.這一部分我不可能細講,因為內(nèi)容太多了,而且對于不同的項目有不同的內(nèi)容,在查閱資料的過程也是提升技術(shù)的一個重要的環(huán)節(jié),你可以真真切切的了解到開發(fā)一個工程是需要哪方面的知識,因此我就對我所選的這個課題應(yīng)該使用到的技術(shù)棧進行一下介紹,也算是拋磚引玉,各位同學(xué)可以根據(jù)自己的實際情況進行撰寫.
開發(fā)不同的系統(tǒng)雖然涉及到的業(yè)務(wù)邏輯不同,處理方式也千差萬別,但是本質(zhì)上都是一樣的,都是前端界面通過服務(wù)器跟數(shù)據(jù)庫進行數(shù)據(jù)交互的一個過程,涉及到的內(nèi)容也無非就是前端、后臺和服務(wù)器.但是有一個需要注意的點,就是不要把HTML、JAVA等使用的語言介紹也給堆在這里,老師沒細看還好,細看還是會顯得太水字數(shù)了,記住,寫工程性的課題不怕沒字數(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. 后臺
這一部分是重點,對于本課題來說,標題就寫了是基于SSM的.對于這個java框架并不熟悉的同學(xué)來說建議先去查一下資料,而且很多同學(xué)會有疑問,使用技術(shù)框架的目的就是為了讓開發(fā)更加的便捷和快速,但是為什么我們自己在開發(fā)的過程中會感覺好像變得更加復(fù)雜?很負責任的告訴你,是正常的.因為框架不僅會幫我們封裝好一些常用的方法,而且會考慮到更新迭代以及代碼可讀性等等的一系列的問題,某些規(guī)定和配置我們之所以沒有感受到他的好處是因為這種校園內(nèi)的開發(fā)并不涉及生產(chǎn)問題,也不會有很多的更新迭代,更加不會考慮到代碼的可讀性.例如spring的工廠,一開始使用的時候很多同學(xué)會覺得為什么我new一個類的時候還要去改配置文件,直接new不香嗎?直接new是很香,但是你考慮到真正去工作的時候,假設(shè)你要改類的一些關(guān)系的時候,還要去改代碼,當工程一大,代碼去哪里找呢?一個一個文件看嗎?顯然是非常不可取的,效率非常低,這個時候配置文件的優(yōu)勢就發(fā)揮出來了,直接修改配置文件,不需要更改代碼,耦合性也大大的降低.好像跑題了,說了這么多就告訴同學(xué)們,要沉住氣,理解框架這樣設(shè)計背后的原因,對大家自身技術(shù)的提高非常的有幫助!
那這一部分我們就可以介紹spring(包括spring的IOC、spring的工廠、spring的AOP等等,并且可以在論文中強調(diào)如何應(yīng)用到我們的系統(tǒ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ù)器來搭建了,可以詳細介紹一下云服務(wù)器的搭建過程包括防火墻、端口等等內(nèi)容.一般服務(wù)器使用tomcat進行搭建,可以把tomcat介紹一下并且介紹一下tomcat是如何監(jiān)聽和解析用戶請求的具體流程.
一般小型的項目采用MySQL作為數(shù)據(jù)庫,可以詳細說一下選擇MySQL的原因,比如相對于Oracle的好處.可以介紹一下MySQL數(shù)據(jù)庫的一些特點包括分頁、是否支持事務(wù)等等.
4.第三章:需求分析
這一部分是針對具體的業(yè)務(wù)場景來分析需要開發(fā)哪些功能,這一部分可以讓你感受一下產(chǎn)品經(jīng)理的職責,只不過不需要跟程序員對接,因為你自己就是程序員哈哈.一般來說分成兩部分就可以了,一部分是對于前端的業(yè)務(wù)流程,另一部分就是后臺服務(wù)器的業(yè)務(wù)流程,可以使用一些軟件來繪畫流程圖,想圖個方便可以直接使用word自帶的圖形進行編寫,也不至于難看,就比較簡約.想做的好看點的話個人推薦使用xmind,非常簡單,可以快速做出美觀的流程圖.如果沒有什么思路,那前端就按照著使用者的邏輯去寫,比如用戶需要注冊、登錄、找回密碼、購物、退貨等操作,那后端就對應(yīng)著這些前端邏輯需要有相應(yīng)的業(yè)務(wù)處理.個人感覺這一部分比較好寫,就不再贅述.
5.第四章:系統(tǒng)的設(shè)計和實現(xiàn)
這一部分可以挑選一些有代表性的功能出來細講,有些同學(xué)可能會有疑問,論文可不可以貼代碼呢?答案是可以的.但是我個人的建議是貼偽代碼,不要把你寫的長篇大論的代碼全部放進去,不好看而且邏輯混亂,應(yīng)該做的是把代碼抽取為偽代碼,貼代碼的目的是為了讓閱讀者清晰地讀懂你是如何實現(xiàn)這個功能的,他并不會在意你的語法你的命名.下面列舉若干個可以寫的內(nèi)容,并不限于此.
a. SSM框架的整合.如何使用Spring來整合并且管理SpringMVC和Mybatis.
b. 客戶登錄狀態(tài)保存的實現(xiàn).這一部分可能會涉及到cookies,sessions以及http報文解析等等,都可以詳解.
c. 后臺商品管理的功能.這一部分可以根據(jù)管理員的后臺管理功能進行描寫.
d. 商品搜索功能.可以涉及到數(shù)據(jù)庫的模糊搜索.
e. 數(shù)據(jù)庫表格的設(shè)計.可以體現(xiàn)數(shù)據(jù)庫表格設(shè)計的時候如何遵守三范式.
f. 可以寫在開發(fā)過程中遇到的一些疑難雜癥.
g. 可以寫開發(fā)過程中使用到的一些比較具有亮點的語言特性.比如java的多線程、lambda表達式.又比如實現(xiàn)注冊功能的時候使用的正則表達式.
……
等等數(shù)不勝數(shù).
6.第五章:運行結(jié)果
這一部分非常好寫了.截取一些關(guān)于你的系統(tǒng)的界面并且介紹一下功能,盡量說詳細點,就ok了.
7.第六章:總結(jié)以及展望
這一部分也是比較水的一部分,但是也希望同學(xué)們認真寫一寫.可以寫一下你開發(fā)這個項目的過程中學(xué)習到了什么,可以是XX技術(shù),也可以是艱苦奮斗的精神…….展望可以寫有望發(fā)展成另外一個淘寶……開玩笑開玩笑,總之劈里啪啦湊個幾百字即可.
8.參考文獻
把你開發(fā)過程中參考過的文章、論文貼進去之后,往往會發(fā)現(xiàn)參考文獻不夠,太少了!那怎么辦呢?那就貼一些關(guān)于使用的技術(shù)的文章或者參考手冊咯,雖然大部分是沒看過的,但是還是希望大家可以多少看一看(正義之氣躍然紙上).去知網(wǎng)查找參考文章然后添加到你的參考文獻是非常方便的,只需要找到對應(yīng)的文章并且選擇"引用"功能,即可自動生成引用的文字,直接復(fù)制到你的論文中.
9.致謝
第一步,感謝你的導(dǎo)師,感謝你的院領(lǐng)導(dǎo),感謝你的校領(lǐng)導(dǎo).說的好聽后可能答辯的時候不會太為難你……然后你要感謝你的家人你的舍友你的朋友或者是你家的狗(開玩笑),都可以的,這一部分又輕輕松松兩百字.
大家知道,常用的數(shù)據(jù)庫一般是分為三種: (一)、Access (二)SQL Server(三)MySQL,
下面是一些關(guān)于數(shù)據(jù)庫的詳細資料。
常用的數(shù)據(jù)庫區(qū)別和功能方面:
Access是一種桌面數(shù)據(jù)庫,只適合數(shù)據(jù)量少的應(yīng)用,在處理少量數(shù)據(jù)和單機訪問的數(shù)據(jù)庫時是很好的,效率也很高。但是它的同時訪問客戶端不能多于4個。access數(shù)據(jù)庫有一定的極限,如果數(shù)據(jù)達到100M左右,很容易造成服務(wù)器iis假死,或者消耗掉服務(wù)器的內(nèi)存導(dǎo)致服務(wù)器崩潰。
SQL Server是基于服務(wù)器端的中型的數(shù)據(jù)庫,可以適合大容量數(shù)據(jù)的應(yīng)用,在功能上管理上也要比Access要強得多。在處理海量數(shù)據(jù)的效率,后臺開發(fā)的靈活性,可擴展性等方面強大。因為現(xiàn)在數(shù)據(jù)庫都使用標準的SQL語言對數(shù)據(jù)庫進行管理,所以如果是標準SQL語言,兩者基本上都可以通用的。92HeZu網(wǎng)全部雙線合租空間均可使用Access數(shù)據(jù)庫,同時也支持SQL Server。SQL Server還有更多的擴展,可以用存儲過程,數(shù)據(jù)庫大小無極限限制。
SQL Server 特點:
1.真正的客戶機/服務(wù)器體系結(jié)構(gòu)。
2.圖形化用戶界面,使系統(tǒng)管理和數(shù)據(jù)庫管理更加直觀、簡單。
3.豐富的編程接口工具,為用戶進行程序設(shè)計提供了更大的選擇余地。
4.SQL Server與Windows NT完全集成,利用了NT的許多功能,如發(fā)送和接受消息,管理登錄安全性等。SQL Server也可以很好地與microsoft BackOffice產(chǎn)品集成。
5.具有很好的伸縮性,可跨越從運行Windows 95/98的膝上型電腦到運行Windows 2000的大型多處理器等多種平臺使用。
6.對Web技術(shù)的支持,使用戶能夠很容易地將數(shù)據(jù)庫中的數(shù)據(jù)發(fā)布到Web頁面上。
7.SQL Server提供數(shù)據(jù)倉庫功能,這個功能只在Oracle和其他更昂貴的DBMS中才有。
MySQL是一個開放源碼的小型關(guān)系型數(shù)據(jù)庫管理系統(tǒng),開發(fā)者為瑞典MySQL AB公司,92HeZu網(wǎng)免費贈送MySQL。目前MySQL被廣泛地應(yīng)用在Internet上的中小型網(wǎng)站中。提供由于其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點,許多中小型網(wǎng)站為了降低網(wǎng)站總體擁有成本而選擇了MySQL作為網(wǎng)站數(shù)據(jù)庫。
MySQL特點:
1.MySql的核心程序采用完全的多線程編程。線程是輕量級的進程,它可以靈活地為用戶提供服務(wù),而不過多的系統(tǒng)資源。
2.MySql可運行在不同的操作系統(tǒng)下。簡單地說,MySql可以支持Windows95/98/NT/2000以及UNIX、Linux和SUN OS等多種操作系統(tǒng)平臺。
3.MySql有一個非常靈活而且安全的權(quán)限和口令系統(tǒng)。當客戶與MySql服務(wù)器連接時,他們之間所有的口令傳送被加密,而且MySql支持主機認證。
4.MySql支持ODBC for Windows。MySql支持所有的ODBC 2.5函數(shù)和其他許多函數(shù),這樣就可以用Access連接MySql服務(wù)器,從而使得MySql的應(yīng)用被大大擴展。
5.MySql支持大型的數(shù)據(jù)庫。雖然對于用Php編寫的網(wǎng)頁來說只要能夠存放上百條以上的記錄數(shù)據(jù)就足夠了,但MySql可以方便地支持上千萬條記錄的數(shù)據(jù)庫。
6.MySql擁有一個非??焖俣曳€(wěn)定的基于線程的內(nèi)存分配系統(tǒng),可以持續(xù)使用面不必擔心其穩(wěn)定性。
7.強大的查詢功能。MySql支持查詢的SELECT和WHERE語句的全部運算符和函數(shù),并且可以在同一查詢中混用來自不同數(shù)據(jù)庫的表,從而使得查詢變得快捷和方便。
8.PHP為MySql提供了強力支持,PHP中提供了一整套的MySql函數(shù),對MySql進行了全方位的支持