版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、<p> 《數(shù)據(jù)庫課程設計》任務書</p><p><b> 一、課程設計的目的</b></p><p> 《數(shù)據(jù)庫課程設計》是軟件工程專業(yè)(本科)教學大綱要求的重要實踐性環(huán)節(jié)之一,是學習完《數(shù)據(jù)庫原理及應用》和《Oracle數(shù)據(jù)庫應用》兩門課程后進行的一次數(shù)據(jù)庫方面的綜合練習。其目的在于:配合《數(shù)據(jù)庫原理及應用》和《Oracle數(shù)據(jù)庫應用》課程的教學
2、,使學生能鞏固和加深對數(shù)據(jù)庫基礎理論和基本知識的理解;掌握使用數(shù)據(jù)庫進行軟件設計的基本思想和方法;提高學生運用數(shù)據(jù)庫理論解決實際問題的能力;培養(yǎng)學生調查研究、查閱技術文獻、資料、手冊以及編寫技術文獻的能力。</p><p> 二、課程設計的內容及要求</p><p> 內容:用一種高級語言和當前流行的數(shù)據(jù)庫管理系統(tǒng)相結合,完成一個小型管理系統(tǒng)的設計與開發(fā)。所設計的小型管理系統(tǒng)應包含兩個
3、以上(不多于4個)的模塊以及輸入輸出、查詢、插入、刪除等基本功能。根據(jù)課程設計2周時間的安排選擇適當大小的設計課題,課題的選擇可以是實際問題,也可以是虛構的問題。根據(jù)題目的基本需求,畫出系統(tǒng)結構圖,并對數(shù)據(jù)庫進行詳細設計,編寫程序,同時寫出關于本數(shù)據(jù)庫管理系統(tǒng)的報告書。</p><p><b> 要求:</b></p><p> (1) 要求學生按照《數(shù)據(jù)庫原理及
4、應用》和《Oracle數(shù)據(jù)庫應用》相關知識以及《數(shù)據(jù)庫課程設計》教學大綱完成一個數(shù)據(jù)庫設計,并撰寫相應的課程設計報告。</p><p> (2)提交課程設計報告。</p><p> 要求完成課程設計報告大約15頁-20頁,包括相應的模塊設計文檔、數(shù)據(jù)庫設計文檔、所承擔模塊的核心代碼、測試過程分析與運行結果等。分組進行的同學共同完成基本設計與數(shù)據(jù)庫設計,但每個人至少必須獨立完成一個模塊設
5、計與實現(xiàn),并寫入課程設計報告中。</p><p><b> 三、課程設計時間</b></p><p> 課程設計時間為2周(10個工作日)</p><p><b> 四、課程設計分組</b></p><p><b> 一人一組</b></p><p&
6、gt; 五、課程設計的成果和形式</p><p><b> 1.報告一篇</b></p><p> 建議論文按下列的提綱書寫</p><p> 2.符合設計要求的數(shù)據(jù)庫應用系統(tǒng)一個</p><p><b> 指導教師簽字:</b></p><p><b>
7、 年 月 日</b></p><p><b> 目 錄</b></p><p><b> 1 需求分析4</b></p><p><b> 1.1 引言4</b></p><p> 1.2 任務概述4</p><p>
8、; 1.2.1 用戶角色4</p><p> 1.2.2 管理員角色5</p><p> 2 數(shù)據(jù)庫概要設計5</p><p> 2.1 邏輯模型5</p><p> 2.2 數(shù)據(jù)字典5</p><p> 3. 數(shù)據(jù)庫邏輯設計7</p><p> 3.1 關系模式7&
9、lt;/p><p> 3.2 實體間的關系7</p><p> 3.3 完整性約束7</p><p><b> 3.4 范式7</b></p><p> 3.5 DBMS選擇7</p><p> 4. 數(shù)據(jù)庫實施8</p><p> 4.1 基于SQL
10、Server的數(shù)據(jù)表設計8</p><p> 4.1.1教工信息表8</p><p> 4.1.2 用戶信息表8</p><p> 4.1.3 工資等級表8</p><p><b> 4.2 角色8</b></p><p><b> 4.3 關系圖9</b&g
11、t;</p><p><b> 5 系統(tǒng)實現(xiàn)9</b></p><p> 5.1 登陸界面9</p><p> 5.2主菜單界面12</p><p><b> 參考文獻17</b></p><p><b> 附件:18</b><
12、/p><p><b> 1 需求分析</b></p><p><b> 1.1 引言</b></p><p> 隨著全球信息化的發(fā)展,人事信息化建設也趕上時代的步伐。工資管理系統(tǒng)的主要目標是支持企、事業(yè)的財政管理與事務處理業(yè)務人員的勞動強度,輔助企、事業(yè)管理,輔助高層領導決策,提高企、事業(yè)的工作效率,從而使企、事業(yè)能夠以
13、少的投入獲得更好的社會效益與經濟效益,像人事系統(tǒng)、工資管理系統(tǒng)等就屬于人事工資管理系統(tǒng)的范疇。它是單位實現(xiàn)現(xiàn)代化建設的基礎工程,是提高單位的管理水平、業(yè)務的運轉效率和服務質量的必要手段。因此許多的程序員都可能面對如何開發(fā)一套比較完善的人事工資管理系統(tǒng)是相當有必要的問題。</p><p> 隨著計算機技術的飛速發(fā)展,計算機在企、事業(yè)管理中應用的普及,利用計算機實現(xiàn)企、事業(yè)人事工資的管理勢在必行。本系統(tǒng)結合人事、財
14、務制度,經過需求分析、總體設計和詳細設計,采用功能強大的Visual C++6.0作為開以語言,以Microsoft access作為后臺數(shù)據(jù)庫,來開發(fā)模擬我校的、單機版的人事工資管理系統(tǒng)。</p><p> 整個系統(tǒng)從符合操作簡便、接口友好、靈活、實用、安全的要求出發(fā),完成人事、工資管理的全過程,包括新進員工加入時人事檔案的建立、老員工的轉出、職位等的變動引起職工信息的修改、員工信息查詢、統(tǒng)計等人事管理工作以
15、及新進員工工資的新增、老員工工資修改等工資管理工作。</p><p> 論文主要介紹了本課題的開發(fā)背景,所要完成的功能和開發(fā)的過程。重點說明了系統(tǒng)設計的重點、思想、難點技術和解決方案。</p><p><b> 1.2 任務概述</b></p><p> 教師工資管理系統(tǒng)共有2個角色選擇:用戶角色,管理員角色。</p>&l
16、t;p> 1.2.1 用戶角色</p><p> 玩家角色能夠實現(xiàn)如下2項功能:</p><p> 1. 信息查詢:用戶可以查詢自己工資的發(fā)放情況</p><p> 2. 密碼修改:用戶可以修改需要更改的密碼</p><p> 1.2.2 管理員角色</p><p> 管理員角色能夠實現(xiàn)如下3項功能:
17、</p><p> 1.添加功能:向系統(tǒng)中添加新的數(shù)據(jù)</p><p> 2.刪除功能:刪除系統(tǒng)中不需要的數(shù)據(jù)</p><p> 3.修改功能:修改系統(tǒng)中修要更新的數(shù)據(jù)</p><p><b> 2 數(shù)據(jù)庫概要設計</b></p><p><b> 2.1 邏輯模型</b
18、></p><p> 圖2-1總體邏輯模型</p><p><b> 2.2 數(shù)據(jù)字典</b></p><p> 表2-1 工資信息數(shù)據(jù)字典表</p><p> 表 1.2 教工工資數(shù)據(jù)字典表</p><p> 表 1.3 教工信息數(shù)據(jù)字典表</p><p&g
19、t;<b> E-R圖</b></p><p> 根據(jù)所要實現(xiàn)的功能設計,可能建立它們之間的關系,進而實現(xiàn)邏輯結構功能。</p><p> 教師工資管理系統(tǒng)可劃分3個實體: </p><p> 用E-R圖描述這些實體。</p><p> 3. 數(shù)據(jù)庫邏輯設計</p><p><b&
20、gt; 3.1 關系模式</b></p><p> 本系統(tǒng)含有3個實體,將之轉換為2個關系模式 </p><p> 種族-職業(yè)選擇(種族名稱,職業(yè)名稱)</p><p> 職業(yè)-裝備選擇(職業(yè)名稱,裝備屬性,裝備名稱)</p><p> 3.2 實體間的關系</p><p> 本系統(tǒng)含有3個實體
21、( 為主碼, 為外碼)</p><p> 職稱(種族名稱,陣營,職業(yè)名稱,種族介紹)</p><p> 教工(職業(yè)名稱,裝備屬性,職業(yè)介紹,種族名稱)</p><p> 裝備(裝備名稱,裝備屬性,裝備部位,傷害加成,暴擊加成,急速加成)</p><p><b> 3.3 完整性約束</b><
22、/p><p> 3.3.1實體完整性:3個實體中的4個主碼都不為空,滿足實體完整性。</p><p> 3.3.2參照完整性:3個實體之間外碼已經給出,都能找到主碼關系表中屬性與之對應,滿足參照完整性</p><p><b> 3.4 范式</b></p><p> 本系統(tǒng)3個實體,眾多屬性之間不存在任何函數(shù)依賴關系
23、,所以滿足第三范式。</p><p> 3.5 DBMS選擇</p><p> 本系統(tǒng)選擇SQL Server為數(shù)據(jù)庫管理系統(tǒng)。</p><p><b> 4. 數(shù)據(jù)庫實施</b></p><p> 4.1 基于SQL Server的數(shù)據(jù)表設計</p><p> 4.1.1教工信息表&
24、lt;/p><p><b> 圖4-1 種族表</b></p><p> 4.1.2 用戶信息表</p><p><b> 圖 4-2 職業(yè)表</b></p><p> 4.1.3 工資等級表</p><p><b> 圖 4-3 裝備表</b>&
25、lt;/p><p><b> 4.2 角色</b></p><p> 建立了用戶和管理員2個角色</p><p> 用戶角色:只能執(zhí)行查詢和密碼修改操作。</p><p> 管理員角色:能進行查詢,修改,添加,刪除操作。</p><p><b> 4.3 關系圖</b>
26、</p><p><b> 圖 4-4 關系圖</b></p><p><b> 5 系統(tǒng)實現(xiàn)</b></p><p><b> 5.1 登陸界面</b></p><p> package salary;</p><p> import jav
27、a.awt.*;</p><p> import javax.swing.*;</p><p> import java.awt.event.*;</p><p> import java.sql.*;</p><p> class LandFrame extends JFrame</p><p><b&
28、gt; {</b></p><p> JComboBox list;</p><p> JLabel jLabel1;</p><p> JLabel jLabel2;</p><p> JTextField jtf1;</p><p> //TextField jtf2;</p>
29、<p> JPasswordField jpwf;</p><p> JButton jbtn,jbtn1;</p><p> LandFrame(String s)</p><p><b> {</b></p><p><b> super(s);</b></p>
30、;<p> setLayout(null);</p><p> setBounds(100,100,500,400);</p><p> list=new JComboBox();</p><p> list.setBorder(BorderFactory.createTitledBorder("請選擇登錄"));</
31、p><p> list.addItem("管理員登錄");</p><p> list.addItem("用戶登錄");</p><p> list.setBounds(175,50,150,50);</p><p> jLabel1=new JLabel("用戶名:");<
32、;/p><p> jLabel2=new JLabel("密碼:");</p><p> jbtn=new JButton("登錄");</p><p> jbtn.addActionListener(new ActionListener(){</p><p> public void action
33、Performed(ActionEvent e)</p><p><b> {</b></p><p> testify();</p><p><b> }</b></p><p><b> });</b></p><p> jbtn1=new
34、 JButton("退出");</p><p> jbtn1.addActionListener(new ActionListener()</p><p><b> {</b></p><p> public void actionPerformed(ActionEvent e)</p><p>
35、;<b> {</b></p><p> dispose();</p><p><b> }</b></p><p><b> });</b></p><p> jtf1=new JTextField(10);</p><p> //jt
36、f2=new TextField(10);</p><p> // jtf2.setEchoChar('*');</p><p> jpwf=new JPasswordField(10);</p><p> jpwf.setEchoChar('*');</p><p> jLabel1.set
37、Bounds(155,150,50,30);</p><p> jLabel2.setBounds(155,190,50,30);</p><p> jtf1.setBounds(210,150,100,25);</p><p> //jtf2.setBounds(230,190,100,25);</p><p> jpwf.se
38、tBounds(210,190,100,25);</p><p> jbtn.setBounds(120,250,80,40);</p><p> jbtn1.setBounds(290,250,80,40);</p><p> //jbtn.setBounds(110,110,50,50);</p><p> Container c
39、on=getContentPane();</p><p> con.add(list);</p><p> con.add(jLabel1);</p><p> con.add(jtf1);</p><p> con.add(jLabel2);</p><p> // con.add(jtf2);&l
40、t;/p><p> con.add(jpwf);</p><p> con.add(jbtn);</p><p> con.add(jbtn1);</p><p> setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);</p><p> getRootPane().
41、setDefaultButton(jbtn);</p><p> setVisible(true);</p><p> //validate();</p><p><b> }</b></p><p> void testify()</p><p><b> {</b&g
42、t;</p><p> String str;</p><p> str=(String)list.getSelectedItem();</p><p> if(str=="管理員登錄")</p><p><b> {</b></p><p> test_manage
43、();</p><p> //System.out.println("Hello");</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p>
44、 test_employee();</p><p><b> }</b></p><p> //System.out.println(list.getSelectedItem());</p><p><b> }</b></p><p> 圖 5-1 登陸界面</p><
45、p><b> 5.2主菜單界面 </b></p><p> package salary;</p><p> import javax.swing.*;</p><p> import java.awt.*;</p><p> import java.awt.event.*;</p><
46、;p> import java.sql.*;</p><p> import javax.swing.table.*;</p><p> import java.util.*;</p><p> /*public class ManageFrame </p><p><b> {</b></p>
47、;<p> public static void main(String[] args)</p><p><b> {</b></p><p> Manage mf=new Manage("工資管理系統(tǒng)");</p><p><b> }</b></p><p&
48、gt;<b> }*/</b></p><p> class ManageFrame extends JFrame </p><p><b> {</b></p><p> JLabel jLabel1,jLabel2,jLabel4,jLabel5,jLabel6,jLabel7;</p><
49、p> JTextField jtf1,jtf2,jtf3,jtf4,jtf5;</p><p> JButton btn1,btn2,btn3,btn4,btn5,btn6,btn7,btn8;</p><p> JComboBox jcb1,jcb2;</p><p> ManageFrame(String s)</p><p&g
50、t;<b> {</b></p><p><b> super(s);</b></p><p> setLayout(null);</p><p> setBounds(100,100,500,500);</p><p> jcb1=new JComboBox();</p>
51、<p> jcb1.addItem("1");</p><p> jcb1.addItem("2");</p><p> jcb1.addItem("3");</p><p> jcb1.addItem("4");</p><p> jcb1.
52、addItem("5");</p><p> jcb1.addItem("6");</p><p> jcb1.addItem("7");</p><p> jcb1.addItem("8");</p><p> jcb1.addItem("9&
53、quot;);</p><p> jcb1.addItem("10");</p><p> jcb1.addItem("11");</p><p> jcb1.addItem("12");</p><p> jcb2=new JComboBox();</p>&
54、lt;p> jcb2.setBorder(BorderFactory.createTitledBorder("請選擇月份"));</p><p> jcb2.addItem("1");</p><p> jcb2.addItem("2");</p><p> jcb2.addItem(&quo
55、t;3");</p><p> jcb2.addItem("4");</p><p> jcb2.addItem("5");</p><p> jcb2.addItem("6");</p><p> jcb2.addItem("7");</
56、p><p> jcb2.addItem("8");</p><p> jcb2.addItem("9");</p><p> jcb2.addItem("10");</p><p> jcb2.addItem("11");</p><p&g
57、t; jcb2.addItem("12");</p><p> jLabel1=new JLabel("員工號:");</p><p> jLabel2=new JLabel("日期:");</p><p> jLabel4=new JLabel("月");</p>
58、<p> jLabel5=new JLabel("工作天數(shù):");</p><p> jLabel6=new JLabel("缺席天數(shù):");</p><p> jLabel7=new JLabel("按月份查詢員工工資:");</p><p> jtf1=new JTextField(
59、10);</p><p> jtf4=new JTextField(2);</p><p> jtf5=new JTextField(2);</p><p> btn1=new JButton("更改基本工資");</p><p> btn1.addActionListener(new ActionListener
60、()</p><p><b> {</b></p><p> public void actionPerformed(ActionEvent e)</p><p><b> {</b></p><p> S_change sc=new S_change("修改工資");&
61、lt;/p><p><b> }</b></p><p><b> });</b></p><p> btn2=new JButton("修改員工信息");</p><p> btn2.addActionListener(new ActionListener()</p&
62、gt;<p><b> {</b></p><p> public void actionPerformed(ActionEvent e)</p><p><b> {</b></p><p> Alter al=new Alter("修改");</p><p&
63、gt;<b> }</b></p><p><b> });</b></p><p> btn3=new JButton("增加員工");</p><p> btn3.addActionListener(new ActionListener()</p><p><b
64、> {</b></p><p> public void actionPerformed(ActionEvent e) </p><p><b> {</b></p><p> IncreaseFrame inf=new IncreaseFrame("增加員工");</p><p
65、><b> }</b></p><p><b> });</b></p><p> btn4=new JButton("刪除員工");</p><p> btn4.addActionListener(new ActionListener()</p><p><
66、b> {</b></p><p> public void actionPerformed(ActionEvent e)</p><p><b> {</b></p><p> Delete dl=new Delete("刪除員工");</p><p><b>
67、}</b></p><p><b> });</b></p><p> btn5=new JButton("查看所有員工信息");</p><p> btn5.addActionListener(new ActionListener(){</p><p> public void
68、actionPerformed(ActionEvent e) {</p><p> // TODO 自動生成方法存根</p><p> lookover();</p><p><b> }</b></p><p><b> });</b></p><p> btn6
69、=new JButton("確定");</p><p> btn6.addActionListener(new ActionListener()</p><p><b> {</b></p><p> public void actionPerformed(ActionEvent e) {</p><
70、;p> // TODO 自動生成方法存根</p><p><b> count();</b></p><p><b> }</b></p><p><b> });</b></p><p> btn7=new JButton("查詢");&l
71、t;/p><p> btn7.addActionListener(new ActionListener()</p><p><b> {</b></p><p> public void actionPerformed(ActionEvent e)</p><p><b> {</b></
72、p><p><b> query();</b></p><p><b> }</b></p><p><b> });</b></p><p> btn8=new JButton("退出");</p><p> btn8.add
73、ActionListener(new ActionListener()</p><p><b> {</b></p><p> public void actionPerformed(ActionEvent e)</p><p><b> {</b></p><p> dispose();&
74、lt;/p><p><b> }</b></p><p><b> });</b></p><p> jLabel1.setBounds(60, 40, 50, 20);</p><p> jtf1.setBounds(115,40,100,20);</p><p>
75、jLabel2.setBounds(300,40,30,20);</p><p> jcb1.setBounds(340,40,45,20);</p><p> jLabel4.setBounds(395,40,20,20);</p><p> jLabel5.setBounds(60,80,60,20);</p><p> jtf4
76、.setBounds(125,80,30,20);</p><p> jLabel6.setBounds(200,80,60,20);</p><p> jtf5.setBounds(265,80,30,20);</p><p> jLabel7.setBounds(80,120,130,30);</p><p> jcb2.setB
77、ounds(215,120,80,50);</p><p> btn1.setBounds(90,230,130,30);</p><p> btn2.setBounds(270,230,130,30);</p><p> btn3.setBounds(100,290,100,30);</p><p> btn4.setBounds(
78、280,290,100,30);</p><p> btn5.setBounds(150,370,200,30);</p><p> btn6.setBounds(340,75,60,30);</p><p> btn7.setBounds(340,130,60,30);</p><p> btn8.setBounds(200,420
79、,80,30);</p><p> Container con=getContentPane();</p><p> con.add(jLabel1);</p><p> con.add(jtf1);</p><p> con.add(jLabel2);</p><p> con.add(jcb1);<
80、/p><p> con.add(jLabel4);</p><p> con.add(jLabel5);</p><p> con.add(jtf4);</p><p> con.add(jLabel6);</p><p> con.add(jtf5);</p><p> con.add
81、(jLabel7);</p><p> con.add(jcb2);</p><p> con.add(btn1);</p><p> con.add(btn2);</p><p> con.add(btn3);</p><p> con.add(btn4);</p><p> co
82、n.add(btn5);</p><p> con.add(btn6);</p><p> con.add(btn7);</p><p> con.add(btn8);</p><p> setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);</p><p> s
83、etVisible(true);</p><p><b> }</b></p><p> 圖5-2 主菜單界面</p><p><b> 參考文獻</b></p><p> [1] 耿祥主編.JAVA 2 實用教程.清華大學出版社.2006.8</p><p> [
84、2] 錢雪忠主編.數(shù)據(jù)庫原理及應用[M].北京郵電大學出版社.2007.8 </p><p> [3] 朱輝生主編.大型數(shù)據(jù)庫系統(tǒng)概論.高等教育出版社.2006.9</p><p> [4] 陳昊鵬主編.Java編程思想.機械工業(yè)出版社.2007.6</p><p> [5] 李鐘尉主編.Java從入門到精通.清華大學出版社.2008.9</p>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 課程設計--教師工資管理系統(tǒng)
- 課程設計--教師工資管理系統(tǒng)
- jsp教師工資管理系統(tǒng)
- 教師工資管理系統(tǒng)-計算機語言b課程設計
- 教師工資管理系統(tǒng)-軟件工程
- c++課設教師工資管理系統(tǒng)
- 工資管理系統(tǒng)課程設計
- 工資管理系統(tǒng)課程設計
- 課程設計-工資管理系統(tǒng)
- 工資管理系統(tǒng)課程設計
- 工資管理系統(tǒng)課程設計
- 工資管理系統(tǒng)(課程設計)
- jsp教師工資管理系統(tǒng)論文.doc
- 課程設計-- 企業(yè)工資管理系統(tǒng)
- 企業(yè)工資管理系統(tǒng)課程設計
- 工資管理系統(tǒng)-課程設計報告
- 企業(yè)工資管理系統(tǒng)課程設計
- 企業(yè)工資管理系統(tǒng)課程設計
- sql課程設計---工資管理系統(tǒng)
- java工資管理系統(tǒng)課程設計
評論
0/150
提交評論