版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 《C#程序設(shè)計》</b></p><p><b> 課程設(shè)計報告</b></p><p> ?。?012 — 2013 學(xué)年 第 2 學(xué)期)</p><p> 題 目: 學(xué)生成績信息管理系統(tǒng) </p><p&g
2、t; 專 業(yè): 計算機(jī)應(yīng)用 </p><p> 班 級: </p><p> 姓名學(xué)號: </p><p> 指導(dǎo)教師:
3、 </p><p> 成 績: </p><p><b> 目錄</b></p><p><b> 摘 要1</b></p><p><b> 第一章 緒 論2</b></p>&
4、lt;p> 1.1 設(shè)計目的2</p><p> 1.2 開發(fā)工具選擇2</p><p> 1.3 開發(fā)環(huán)境2</p><p> 1.4 本報告的主要內(nèi)容2</p><p> 第二章 需求分析3</p><p> 2.1系統(tǒng)需求簡介3</p><p> 2.1.1
5、系統(tǒng)目標(biāo)3</p><p> 2.1.2功能需求分析3</p><p> 2.1.3性能需求分析3</p><p> 第三章 總體設(shè)計4</p><p><b> 3.1設(shè)計概述4</b></p><p> 3.2系統(tǒng)總體結(jié)構(gòu)及功能模塊劃分4</p><p
6、> 3.2.1學(xué)生信息查詢模塊4</p><p> 3.2.2學(xué)生信息管理模塊5</p><p> 3.3系統(tǒng)數(shù)據(jù)庫概念結(jié)構(gòu)設(shè)計5</p><p> 3.3.1系統(tǒng)E-R圖5</p><p> 3.3.2系統(tǒng)數(shù)據(jù)庫的設(shè)計6</p><p> 3.4安全保密設(shè)計7</p>&l
7、t;p> 3.4.1用戶登錄安全性7</p><p> 第四章 詳細(xì)設(shè)計8</p><p><b> 4.1概述8</b></p><p> 4.2系統(tǒng)程序流程圖8</p><p> 4.3系統(tǒng)主要功能模塊簡介9</p><p> 4.3.1系統(tǒng)登錄9</p&g
8、t;<p> 4.3.2學(xué)生信息查詢模塊9</p><p> 4.3.3學(xué)生信息管理模塊10</p><p> 第五章 主要功能模塊代碼12</p><p> 5.1 公共類代碼設(shè)計12</p><p> 5.2 登錄界面代碼設(shè)計14</p><p> 5.3 查詢模塊代碼設(shè)計15
9、</p><p> 5.4 添加模塊代碼設(shè)計16</p><p> 5.5 更新模塊代碼設(shè)計17</p><p> 5.6 刪除模塊代碼設(shè)計20</p><p> 第六章 課程設(shè)計心得21</p><p> 第七章 設(shè)計日志22</p><p> C#學(xué)生成績管理系統(tǒng)<
10、;/p><p><b> 摘 要</b></p><p> 本文描述的是基于Windows環(huán)境的學(xué)生信息管理系統(tǒng),主要功能模塊包括:學(xué)生信查詢,學(xué)生信息管理,學(xué)生成績錄入,主要工具M(jìn)icrosoft Visual Studio 2010 設(shè)計窗體, SQL server2005建立數(shù)據(jù)庫,實現(xiàn)學(xué)校信息管理的各個功能。</p><p> 本篇
11、報告介紹一個學(xué)生信息管理系統(tǒng)的從分析到設(shè)計最后到開發(fā)的全過程為,給出了學(xué)生信息管理系統(tǒng)的設(shè)計和技術(shù)實現(xiàn)的過程,特別在細(xì)節(jié)上分析功能和函數(shù)的實現(xiàn)思想。涉及到學(xué)生信息管理的基本功能在本報告中都有相應(yīng)的描述。</p><p><b> 緒 論</b></p><p><b> 1.1 設(shè)計目的</b></p><p> 本
12、課程設(shè)計的目的是使學(xué)生能熟練掌握簡單的簡單Windows窗體應(yīng)用程序的設(shè)計和ADO.net的應(yīng)用,希望通過本次課程設(shè)計鍛煉學(xué)生使用C#語言解決實際問題的能力。</p><p> 1.2 開發(fā)工具選擇</p><p> 本系統(tǒng)后臺數(shù)據(jù)庫采用Microsoft SQL Server 數(shù)據(jù)庫,該數(shù)據(jù)庫系統(tǒng)在安全性、準(zhǔn)確性和運(yùn)行速度方面有絕對的優(yōu)勢,并且處理數(shù)據(jù)量大,效率高;前臺采用Micro
13、soft 公司的Visual Studio 2005作為主要開發(fā)工具,可與SQL Server 2005數(shù)據(jù)庫無縫鏈接。</p><p><b> 1.3 開發(fā)環(huán)境</b></p><p> 系統(tǒng)開發(fā)平臺:Microsoft Visual Studio2005</p><p><b> 系統(tǒng)開發(fā)語言:C#</b>&l
14、t;/p><p> 數(shù)據(jù)庫管理軟件:SQL Server 2005</p><p> 1.4 本報告的主要內(nèi)容</p><p> 本報告詳細(xì)的介紹了學(xué)生信息管理系統(tǒng)的開發(fā)過程,主要涉及到的工作如下:系統(tǒng)的需求分析、系統(tǒng)的總體設(shè)計、系統(tǒng)的概念設(shè)計、系統(tǒng)各模塊的詳細(xì)設(shè)計、系統(tǒng)運(yùn)行與測試。</p><p><b> 需求分析</
15、b></p><p><b> 2.1系統(tǒng)需求簡介</b></p><p><b> 2.1.1系統(tǒng)目標(biāo)</b></p><p> 根據(jù)查詢條件實現(xiàn)學(xué)生信息的查詢</p><p> 學(xué)生選課信息查詢、成績信息的查詢</p><p> 學(xué)生信息、課程信息、成績信
16、息的增加、刪除、修改</p><p> 對基本信息完成增加、刪除、修改時,需注意表與表之間的關(guān)聯(lián)</p><p> 2.1.2功能需求分析</p><p> 本系統(tǒng)的功能需求分析如下:</p><p> 學(xué)生信息查詢:學(xué)生可以根據(jù)學(xué)號、姓名、專業(yè)進(jìn)行查詢.</p><p> 學(xué)生信息管理:主要是用于學(xué)生信息更
17、新、插入、刪除;</p><p> 學(xué)生成績錄入:用于學(xué)生成績管理,錄入學(xué)生成績,也可以更新;</p><p> 2.1.3性能需求分析</p><p> 登錄、用戶界面需求:簡潔、易懂、易用、友好的用戶界面。</p><p> 安全保密性需求:只有憑借用戶名和密碼登陸系統(tǒng),才能進(jìn)行信息的管理等。</p><p&g
18、t;<b> 總體設(shè)計</b></p><p><b> 3.1設(shè)計概述</b></p><p> 根據(jù)需求把整個系統(tǒng)分化成不同的模塊,每個模塊完成一個特定的子功能。把這些模塊結(jié)合起來組成一個整體。逐一實現(xiàn)各個功能;</p><p> 3.2系統(tǒng)總體結(jié)構(gòu)及功能模塊劃分</p><p> 經(jīng)
19、過對系統(tǒng)的需求分析,學(xué)生信息管理系統(tǒng)主要劃分為三個部分:學(xué)生信息查詢,學(xué)生信息管理,學(xué)生成績錄入三個功能模塊。如圖3.2.1 系統(tǒng)的總體結(jié)構(gòu)。</p><p> 圖3.2.1 系統(tǒng)的總體結(jié)構(gòu)</p><p> 3.2.1學(xué)生信息查詢模塊</p><p> 學(xué)生信息查詢:學(xué)生可以根據(jù)學(xué)號、姓名、專業(yè)進(jìn)行查詢。如圖3.2.2學(xué)生信息查詢模塊結(jié)構(gòu)。</p&g
20、t;<p> 圖3.2.2 學(xué)生信息管理模塊結(jié)構(gòu)</p><p> 3.2.2學(xué)生信息管理模塊</p><p> 學(xué)生信息管理:主要是用于學(xué)生信息更新、插入、刪除,如圖3.2.3學(xué)生管理模塊結(jié)構(gòu)。</p><p> 圖3.2.3 學(xué)生信息管理模塊結(jié)構(gòu)</p><p> 3.3系統(tǒng)數(shù)據(jù)庫概念結(jié)構(gòu)設(shè)計</p>
21、<p> 根據(jù)對數(shù)據(jù)項與數(shù)據(jù)結(jié)構(gòu)的分析,設(shè)計出能夠滿足系統(tǒng)需求的各種實體,及它們之間的關(guān)系,為后面的邏輯結(jié)構(gòu)設(shè)計打下基礎(chǔ)。</p><p> 3.3.1系統(tǒng)E-R圖</p><p> 系統(tǒng)E-R圖可以將各個實體之間的關(guān)系顯示出來,將各個實體間的屬性依賴表示明白。如圖3.3.1系統(tǒng)E-R圖結(jié)構(gòu)。</p><p> 圖3.3.1系統(tǒng)E-R圖結(jié)構(gòu)&l
22、t;/p><p> 3.3.2系統(tǒng)數(shù)據(jù)庫的設(shè)計</p><p> 綜合以上分析,要實現(xiàn)上面的所有功能模塊,主要設(shè)計表如下: </p><p> 表3.3.1 用戶表(usedata)</p><p> 表3.3.2成績表(SC)</p><p> 表3.3.3課程表 (C)</p><p&
23、gt; 表3.3.4學(xué)生表(S)</p><p><b> 3.4安全保密設(shè)計</b></p><p> 3.4.1用戶登錄安全性</p><p> 系統(tǒng)設(shè)計了登錄界面,每個合法用戶有用戶名及一個密碼,只有當(dāng)用戶輸入正確的用戶名及密碼組合后才能夠?qū)W(xué)生信息進(jìn)行操作。</p><p><b> 詳細(xì)設(shè)計
24、</b></p><p><b> 4.1概述</b></p><p> 詳細(xì)設(shè)計階段的根本目標(biāo)是確定應(yīng)該怎樣具體的實現(xiàn)所要求的系統(tǒng),也就是說,經(jīng)過這個階段的設(shè)計工作,應(yīng)該得出目標(biāo)系統(tǒng)的精確描述,從而在編碼階段可以把這個描述直接翻譯成用某種程序設(shè)計語言書寫的程序。</p><p> 4.2系統(tǒng)程序流程圖</p>
25、<p> 程序流程圖又稱為程序框圖,它是歷史悠久使用最廣泛的描述軟件設(shè)計的方法。它可將整個程序的總體流程清楚明白的顯示出來。如圖4.2.1系統(tǒng)總流程圖結(jié)構(gòu)。</p><p> 圖4.2.1系統(tǒng)總體流程圖</p><p> 4.3系統(tǒng)主要功能模塊簡介</p><p><b> 4.3.1系統(tǒng)登錄</b></p>&
26、lt;p> 用戶憑借用戶名及密碼登錄,成功登錄后可對學(xué)生信息進(jìn)行操作。用戶界面如圖4.3.1 用戶登錄界面所示。</p><p> 圖4.3.1 用戶登錄界面</p><p> 4.3.2學(xué)生信息查詢模塊</p><p> 學(xué)生信息查詢:在程序主界面(如圖4.3.2 程序主界面)學(xué)生可以根據(jù)學(xué)號、姓名進(jìn)行查詢。學(xué)生也可以只用一種條件進(jìn)行信息查詢,也可
27、以多個條件查詢。雙擊記錄任一單元格可顯示學(xué)生的更詳細(xì)信息(如圖4.3.3 詳細(xì)信息窗口)。</p><p> 圖4.3.2 程序主界面</p><p> 圖4.3.3 詳細(xì)信息窗口</p><p> 4.3.3學(xué)生信息管理模塊</p><p> 學(xué)生信息管理:通過右擊程序主界面的相應(yīng)記錄彈出的上下文菜單(如圖4.3.4 上下文菜單)可
28、對當(dāng)前選定學(xué)生信息進(jìn)行詳細(xì)信息查詢(如圖4.3.3 詳細(xì)信息窗口)、修改信息(如圖4.3.5 修改信息窗口)、刪除信息(如圖 4.3.6 刪除信息提示)。更新時如果輸入的學(xué)號不存在,可選擇是否添加學(xué)生信息。通過程序主界面的新建信息記錄可添加學(xué)生信息(如圖 4.3.7 添加信息窗口)。</p><p> 圖4.3.4 上下文菜單</p><p> 圖4.3.5 修改信息窗口</p&
29、gt;<p> 圖4.3.6 刪除信息提示</p><p> 圖4.3.7 添加信息窗口</p><p><b> 主要功能模塊代碼</b></p><p> 5.1 公共類代碼設(shè)計</p><p> namespace MySql</p><p><b> {
30、</b></p><p> public class mySql</p><p><b> {</b></p><p> public String connectionString = @"SERVER=.\SQLEXPRESS;AttachDbFilename=D:\學(xué)習(xí)\C#\課程設(shè)計\StuScoreManS
31、ystem\StuScoreManSystem\StuScoManSys.mdf;</p><p> Integrated Security=True;Connect Timeout=30;User Instance=True;";</p><p> public String commondText;</p><p> public bool fl
32、ag; //指示有條該條記錄</p><p> public System.Data.DataView table;</p><p> public void runSql() // 執(zhí)行查詢、刪除SQL語句</p><p><b> {</b></p><p> using (SqlConnecti
33、on connection = new SqlConnection(connectionString))</p><p><b> {</b></p><p> connection.Open();</p><p> SqlCommand cmdQuery = new SqlCommand(commondText, connection)
34、;</p><p> SqlDataAdapter sda = new SqlDataAdapter(commondText, connection);</p><p> DataSet ds = new DataSet();</p><p> sda.Fill(ds);</p><p> if (commondText.IndexO
35、f("SELECT") >= 0)</p><p><b> {</b></p><p> table = ds.Tables[0].DefaultView;</p><p><b> }</b></p><p> connection.Close();</p
36、><p><b> }</b></p><p><b> }</b></p><p> public bool getFlag() //判斷是否有該條記錄</p><p><b> {</b></p><p> using (SqlConnec
37、tion connection = new SqlConnection(connectionString))</p><p><b> {</b></p><p> connection.Open();</p><p> SqlCommand cmdQuery = new SqlCommand(commondText, connectio
38、n);</p><p> SqlDataReader reader = cmdQuery.ExecuteReader();</p><p> if (reader.Read()) flag = true;</p><p> else flag = false;</p><p> reader.Close();</p>&
39、lt;p> connection.Close();</p><p> return flag;</p><p><b> }</b></p><p><b> }</b></p><p> public String getContent(String require,String
40、SNO) //獲取視圖表的的指定單元格內(nèi)容</p><p><b> {</b></p><p><b> try</b></p><p><b> {</b></p><p> commondText = "SELECT " + requir
41、e + " FROM detail WHERE 學(xué)號=" + SNO;</p><p> if (require == "up課程名稱")</p><p> commondText = "SELECT 課程名稱 FROM detail WHERE 學(xué)號=" + SNO;</p><p> if (re
42、quire == "up成績")</p><p> commondText = "SELECT 成績 FROM detail WHERE 學(xué)號=" + SNO;</p><p> SqlDataAdapter sda = new SqlDataAdapter(commondText, connectionString);</p>&
43、lt;p> DataSet ds = new DataSet();</p><p> sda.Fill(ds);</p><p> String result="";</p><p> if(require=="課程名稱"||require=="成績")</p><p>
44、;<b> {</b></p><p> int i=new int();</p><p> for (i=0; i <ds.Tables[0].Rows.Count; i++) </p><p><b> {</b></p><p> result = result+ds.Tabl
45、es[0].Rows[i][require].ToString()+"\n";</p><p><b> }</b></p><p><b> }</b></p><p><b> else</b></p><p> result=ds.Tables
46、[0].Rows[0][require].ToString().Trim();</p><p> return result;</p><p><b> }</b></p><p><b> catch </b></p><p><b> {</b></p>
47、<p> return "無";</p><p><b> }</b></p><p><b> }</b></p><p> public void update() </p><p> {//添加、更新語句</p><p>&l
48、t;b> try</b></p><p><b> {</b></p><p> using (SqlConnection connection = new SqlConnection(connectionString))</p><p><b> {</b></p><p&g
49、t; connection.Open();</p><p> SqlCommand cmdInsert = new SqlCommand(commondText, connection);</p><p> cmdInsert.ExecuteNonQuery();</p><p> connection.Close();</p><p&g
50、t;<b> }</b></p><p><b> }</b></p><p> catch(Exception ex)</p><p><b> {</b></p><p> MessageBox.Show(ex.ToString(), "提示"
51、);</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> 5.2 登錄界面代碼設(shè)計</p>
52、<p> private void login_Click(object sender, EventArgs e)</p><p> {//用戶名及密碼組合判斷</p><p> if (username.Text.ToString().Trim() != "" && password.Text.ToString().Trim() !=
53、 "")</p><p><b> {</b></p><p> mySql sql = new mySql();</p><p> sql.commondText = "SELECT * FROM userdata WHERE USERNAME='" + username.Text.ToS
54、tring().Trim() + "' AND PASSWORD='" + password.Text.ToString().Trim() + "'";</p><p><b> try</b></p><p><b> {</b></p><p> b
55、ool temp = new bool();</p><p> temp = sql.getFlag();</p><p><b> if (temp)</b></p><p><b> {</b></p><p> this.Visible = false;</p><
56、p> mainface main = new mainface(this);</p><p> main.Show();</p><p><b> }</b></p><p><b> }</b></p><p> catch(Exception ex)</p><
57、;p><b> {</b></p><p> MessageBox.Show(ex.ToString(),"提示");</p><p><b> }</b></p><p><b> }</b></p><p><b> else&
58、lt;/b></p><p><b> {</b></p><p> MessageBox.Show("請輸入用戶名和密碼","提示");</p><p><b> }</b></p><p><b> }</b></
59、p><p> 5.3 查詢模塊代碼設(shè)計</p><p> private void btQuery_Click(object sender, EventArgs e)</p><p><b> {</b></p><p> mySql query=new mySql();</p><p>
60、if (sNInput.Text.Trim() == ""&& sNoinput.Text.Trim()!="") query.commondText = "SELECT SNO AS 學(xué)號,SN AS 姓名,MN AS 專業(yè)名稱,SEX AS 性別,BIRDAY AS 出生日期,TS AS 總學(xué)分,COM AS 備注 FROM S WHERE SNO="+sN
61、oinput.Text.Trim()+"";</p><p> if (sNInput.Text.Trim() != "" && sNoinput.Text.Trim() == "") query.commondText = "SELECT SNO AS 學(xué)號,SN AS 姓名,MN AS 專業(yè)名稱,SEX AS 性別,BIR
62、DAY AS 出生日期,TS AS 總學(xué)分,COM AS 備注 FROM S WHERE SN='" +sNInput.Text.Trim()+ "'";</p><p> if (sNInput.Text.Trim() != "" && sNoinput.Text.Trim() != "") query.co
63、mmondText = "SELECT SNO AS 學(xué)號,SN AS 姓名,MN AS 專業(yè)名稱,SEX AS 性別,BIRDAY AS 出生日期,TS AS 總學(xué)分,COM AS 備注 FROM S WHERE SN='" + sNInput.Text.Trim() + "' and SNO=" + sNoinput.Text.Trim() + "";<
64、;/p><p> if (sNInput.Text.Trim() == "" && sNoinput.Text.Trim() == "") MessageBox.Show("您輸入的信息為空,請重新輸入!", "錯誤信息");</p><p><b> else</b>&l
65、t;/p><p><b> {</b></p><p> if (query.getFlag())</p><p><b> {</b></p><p> query.runSql();</p><p> dataGridView1.DataSource = query
66、.table;</p><p><b> }</b></p><p> else MessageBox.Show("您查找的信息不存在", "錯誤信息");</p><p><b> }</b></p><p><b> }</b>
67、;</p><p> 5.4 添加模塊代碼設(shè)計</p><p> private void addbtOK_Click(object sender, EventArgs e)</p><p><b> {</b></p><p> if (addStuNo.Text.Trim() != ""
68、&& addStuName.Text.Trim() != ""&& addStuMajor.Text.Trim()!="")</p><p><b> {</b></p><p> mySql sql = new mySql();</p><p> sql.commo
69、ndText = "SELECT CNO FROM C WHERE CN='" + listmn.Text.ToString().Trim()+ "'";</p><p> sql.runSql();</p><p> String temp = sql.table.Table.Rows[0]["CNO"].T
70、oString();</p><p> String sexTemp=radioButton1.Checked ? "男":"女";</p><p> String comTemp;</p><p> if (addStuCom.Text.ToString().Trim() == "")</p&
71、gt;<p> comTemp = " ";</p><p> else comTemp = addStuCom.Text.ToString().Trim();</p><p> String birTemp=" ";</p><p> if (addStuBir.Text.ToString().Trim
72、() == "")</p><p> comTemp = " ";</p><p> else birTemp = addStuCom.Text.ToString().Trim();</p><p> sql.commondText = "INSERT INTO S (SNO,SN,MN,SEX,BIRDAY,
73、COM) VALUES("</p><p> +addStuNo.Text.ToString().Trim()+",'" </p><p> +addStuName.Text.ToString().Trim()+"','"</p><p> +addStuMajor.Text.ToSt
74、ring().Trim()+"','"</p><p> +sexTemp+"','"</p><p> +birTemp+"','"</p><p> +comTemp+"');";</p><p>
75、 sql.update();</p><p> if(score.Text.ToString().Trim()!=""){</p><p> sql.commondText = "INSERT INTO SC(SNO,CNO,SCORE) VALUES ("+addStuNo.Text.ToString().Trim()</p>
76、<p> +","+temp+","+score.Text.ToString().Trim()+");";</p><p> sql.update();</p><p><b> }</b></p><p> this.Close();</p><
77、p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> MessageBox.Show("學(xué)號、姓名和專業(yè)名稱都不可以為空?。?!","錯誤!");</p><
78、p><b> }</b></p><p><b> }</b></p><p> private void AddNew_Load(object sender, EventArgs e)</p><p><b> {//獲取專業(yè)列表</b></p><p> m
79、ySql sql = new mySql();</p><p> sql.commondText = "SELECT DISTINCT CN FROM C";</p><p> SqlDataAdapter sda = new SqlDataAdapter(sql.commondText, sql.connectionString);</p><
80、p> DataSet ds = new DataSet();</p><p> sda.Fill(ds);</p><p> listmn.DataSource = ds.Tables[0].DefaultView;</p><p> listmn.DisplayMember = "CN";</p><p>
81、 listmn.DisplayMember = listmn.DisplayMember.ToString().Trim();</p><p><b> }</b></p><p> 5.5 更新模塊代碼設(shè)計</p><p> private void upbtOK_Click(object sender, EventArgs e)&l
82、t;/p><p><b> {</b></p><p> mySql sql = new mySql();</p><p> sql.commondText = "SELECT 學(xué)號 FROM detail WHERE 學(xué)號="+upStuNo.Text.ToString().Trim();</p><
83、p> bool flagtemp = sql.getFlag();</p><p> if (!flagtemp) //如果表中無該條記錄,提示是否進(jìn)行添加新記錄操作</p><p><b> {</b></p><p> if (MessageBox.Show("查無當(dāng)前記錄,無法進(jìn)行更新操作!\n是否進(jìn)行添加新記
84、錄的操作?", "提示", MessageBoxButtons.OKCancel) == DialogResult.OK)</p><p><b> {</b></p><p> if (upStuNo.Text.Trim() != "" && upStuName.Text.Trim() != &q
85、uot;" && upStuMajor.Text.Trim() != "")</p><p><b> {</b></p><p> mySql sqlme = new mySql();</p><p> sqlme.commondText = "SELECT CNO FROM C
86、WHERE CN='" + listmn.Text.ToString().Trim() + "'";</p><p> sqlme.runSql();</p><p> String temp = sqlme.table.Table.Rows[0]["CNO"].ToString();//課程號</p>&
87、lt;p> String sexTemp = radioButton1.Checked ? "男" : "女";</p><p> String comTemp;</p><p> if (upStuCom.Text.ToString().Trim() == "")</p><p> comT
88、emp = " ";</p><p> else comTemp = upStuCom.Text.ToString().Trim();</p><p> String birTemp;</p><p> if (upStuBir.Text.ToString().Trim() == "")</p><p
89、> birTemp = " ";</p><p> else birTemp = upStuCom.Text.ToString().Trim();</p><p> sqlme.commondText = "INSERT INTO S (SNO,SN,MN,SEX,BIRDAY,COM) VALUES("</p><p
90、> + upStuNo.Text.ToString().Trim() + ",'"</p><p> + upStuName.Text.ToString().Trim() + "','"</p><p> + upStuMajor.Text.ToString().Trim() + "','
91、"</p><p> + sexTemp + "','"</p><p> + birTemp + "','"</p><p> + comTemp + "');";</p><p> sqlme.update();</
92、p><p> if (upStuScore.Text.ToString().Trim() != "")</p><p><b> {</b></p><p> sqlme.commondText = "INSERT INTO SC(SNO,CNO,SCORE) VALUES (" + upStuNo.T
93、ext.ToString().Trim()</p><p> + "," + temp + "," + upStuScore.Text.ToString().Trim() + ");";</p><p> sqlme.update();</p><p><b> }</b><
94、;/p><p> this.Close();</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> MessageBox.Show("學(xué)號、姓名和專業(yè)名稱
95、都不可以為空?。?!", "錯誤!");</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> else </b></p>
96、<p><b> {</b></p><p> if (upStuNo.Text.Trim() != "" && upStuName.Text.Trim() != "" && upStuMajor.Text.Trim() != "")</p><p><
97、b> {</b></p><p> sql.commondText = "SELECT CNO FROM C WHERE CN='" + listmn.Text.ToString().Trim() + "'";</p><p> sql.runSql();</p><p> Strin
98、g temp = sql.table.Table.Rows[0]["CNO"].ToString();//獲取課程號</p><p> String sexTemp = radioButton1.Checked ? "男" : "女";</p><p> String comTemp; </p><p&g
99、t; if(upStuCom.Text.ToString().Trim()=="")</p><p> comTemp=" ";</p><p> else comTemp=upStuCom.Text.ToString().Trim();</p><p> String birTemp;</p><
100、p> if (upStuBir.Text.ToString().Trim() == "")</p><p> birTemp = " ";</p><p> else birTemp = upStuBir.Text.ToString().Trim();</p><p> sql.commondText = &qu
101、ot;UPDATE S SET SN='" + upStuName.Text.ToString().Trim() + "',MN='"</p><p> +upStuMajor.Text.ToString().Trim()+"',SEX='"</p><p> +sexTemp+"
102、9;,BIRDAY='"</p><p> + upStuBir.Text.ToString().Trim() + "',COM='"</p><p> +comTemp+"' WHERE SNO="+upStuNo.Text.ToString().Trim();</p><p>
103、 sql.update();</p><p> bool scFlag = new bool();</p><p> if (upStuScore.Text.ToString().Trim() != "")</p><p><b> {</b></p><p><b> try&l
104、t;/b></p><p><b> {</b></p><p> mySql scTemp = new mySql();</p><p> scTemp.commondText = "SELECT CNO FROM C WHERE CN='" + listmn.Text.ToString().Trim(
105、) + "'";</p><p> scTemp.runSql();</p><p> String cntemp = scTemp.table.Table.Rows[0]["CNO"].ToString();//獲取課程號</p><p> scTemp.commondText = "SELECT S
106、NO FROM SC WHERE SNO=" + upStuNo.Text.ToString().Trim() + " AND CNO=" + cntemp;</p><p> scFlag = scTemp.getFlag();</p><p> if (scFlag)</p><p><b> {</b>
107、</p><p> sql.commondText = "UPDATE SC SET SCORE='" + upStuScore.Text.ToString().Trim() + "' WHERE SNO=" + upStuNo.Text.ToString().Trim() + " AND CNO=" + temp;</p>
108、<p> sql.update();</p><p><b> }</b></p><p><b> }</b></p><p><b> catch</b></p><p><b> {</b></p><p&
109、gt; sql.commondText = "INSERT INTO SC(SNO,CNO,SCORE) VALUES (" + upStuNo.Text.ToString().Trim()</p><p> + "," + temp + "," + upStuScore.Text.ToString().Trim() + ");"
110、;</p><p> sql.update();</p><p><b> }</b></p><p><b> }</b></p><p> this.Close();</p><p><b> }</b></p><p&
111、gt;<b> else</b></p><p><b> {</b></p><p> MessageBox.Show("學(xué)號、姓名和專業(yè)名稱都不可以為空?。?!", "錯誤!");</p><p><b> }</b></p><p
112、><b> }</b></p><p><b> }</b></p><p> 5.6 刪除模塊代碼設(shè)計</p><p> private void 刪除記錄ToolStripMenuItem_Click(object sender, EventArgs e)</p><p><
113、b> {</b></p><p> mySql del = new mySql();</p><p> String temp = this.dataGridView1.CurrentRow.Cells[0].Value.ToString();</p><p> if(MessageBox.Show("確定要刪除此條記錄?&quo
114、t;, "提示",MessageBoxButtons.OKCancel)==DialogResult.OK)</p><p><b> {</b></p><p> del.commondText = "DELETE FROM SC WHERE SNO=" + temp;</p><p> del.
115、runSql();</p><p> del.commondText = "DELETE FROM S WHERE SNO=" + temp;</p><p> del.runSql();</p><p> this.dataGridView1.Rows.Remove(this.dataGridView1.CurrentRow);</
116、p><p><b> }</b></p><p><b> }</b></p><p><b> 課程設(shè)計心得</b></p><p> 為期一周的課程設(shè)計結(jié)束了,在老師和同學(xué)的幫助下,我基本完成系統(tǒng)的設(shè)計。我按照系統(tǒng)工程軟件設(shè)計的要求,從需求分析,概念設(shè)計,總體設(shè)計,詳細(xì)
117、設(shè)計,系統(tǒng)測試等各個步驟,分步完成系統(tǒng)的各項任務(wù),實現(xiàn)了系統(tǒng)中的學(xué)生信息查詢,學(xué)生信息更新,學(xué)生信息添加等模塊的功能。</p><p> 在這短短的五天里我收獲如下:</p><p> 1、鞏固和加深了對C#的理解,提高綜合運(yùn)用本課程所學(xué)知識的能力。</p><p> 2、培養(yǎng)了我選用參考書,查閱手冊及文獻(xiàn)資料的能力。培養(yǎng)獨立思考,深入研究,分析問題、解決問題
118、的能力。</p><p> 3、通過實際編譯系統(tǒng)的分析設(shè)計、編程調(diào)試,掌握應(yīng)用軟件的分析方法和工程設(shè)計方法。</p><p> 根據(jù)我在課程設(shè)計中遇到的問題,我將在以后的學(xué)習(xí)當(dāng)中注意以下幾點:</p><p> 1、認(rèn)真上好專業(yè)實驗課,多在實踐中鍛煉自己。</p><p> 2、寫程序的過程中要考慮周到,嚴(yán)密。</p>
119、<p> 3、在做設(shè)計的時候要有信心,有耐心,切勿浮躁。</p><p> 4、認(rèn)真的學(xué)習(xí)課本知識,掌握課本中的知識點,并在此基礎(chǔ)上學(xué)會靈活運(yùn)用。</p><p> 5、在課余時間里多寫程序,熟練掌握在調(diào)試程序的過程中所遇到的常見錯誤,以便能節(jié)省調(diào)試程序的時間。</p><p><b> 設(shè)計日志</b></p>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- c_學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c課程設(shè)計報告--學(xué)生成績管理系統(tǒng)
- c語言課程設(shè)計報告---學(xué)生成績管理系統(tǒng)
- c語言課程設(shè)計報告--學(xué)生成績管理系統(tǒng)
- c語言課程設(shè)計報告----學(xué)生成績管理系統(tǒng)
- c++學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c++學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c語言課程設(shè)計報告--學(xué)生成績管理系統(tǒng)
- c語言課程設(shè)計報告-學(xué)生成績管理系統(tǒng)
- c語言課程設(shè)計報告學(xué)生成績管理系統(tǒng)
- c++學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c++課程設(shè)計報告--學(xué)生成績管理系統(tǒng)
- c語言課程設(shè)計報告--學(xué)生成績管理系統(tǒng)
- 課程設(shè)計報告(學(xué)生成績管理系統(tǒng)c語言)
- c#學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c課程設(shè)計 學(xué)生成績管理系統(tǒng)
- c++課程設(shè)計報告---學(xué)生成績管理系統(tǒng)設(shè)計報告
- c語言學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c語言學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c++程序課程設(shè)計報告—學(xué)生成績管理系統(tǒng)
評論
0/150
提交評論