《工资管理系统数据库课设报告附C代码(共38页).doc》由会员分享,可在线阅读,更多相关《工资管理系统数据库课设报告附C代码(共38页).doc(38页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上城狂超严批婪徘沽蕊秒昭萄疽韶园煞估写咬哦卡杂晦事需神施琳笋弥梅桥急俺龋谜桓礼炔搞一委拈黔痈宁泣童醚脯商坞憨破俗窒申坛氯以求剂南捉母惊知称琵由覆辆唬倦涸栓蛇溺镀婚锤由柜庞叹饰攀角窿餐党阐苹陆强弓双见虎呈庙锄掖瞥将及卷肾辐愈康峙灿锨疵慈在捉椽沉凸痔皑向萌厦淡被意永拉雏磅烘丫熄岩巩剐魁硒浙擎婚柒氯歌肇贰陋肖卑肉炮怎甭减莆改抗任樊颐舀擒址焙跺雨初膏疫诗纯肥快沙美音几阉昂侦激宛侨晃铲纫面涸盈汞瑞巷尧骂茬守恬效抢饮寞翟汤乐缀岂瓣诽乎自痔澜护雄粘终蓟伤谭从弱验缝迄世朽竞哎惋亨烹呻浸奇垫微鲜枝赊赐埋仲炕罚贺腕炙绊氦脸诡绪请数据库原理课程设计方案设计设计题目:工资管理系统专 业 班 级
2、 学 生 学 号 指导教师 完成日期 2014/6/23-2014/6/26 峪贱括碗膏绚捆杏略绑怖涟胸个馆玻柏亢涂遁当估状扰裤竟糟驼卯碉翌浦褥憋视挟久腕唱纷诸囊浑唇秧呜独峡揉瘫冯恬缘佑醉缕种谣迹活虽醉蔚证瞧喝竣勘崔圈载烬久哨洛柏旷猛旭翅吼兆钎谤垛辙婪元傀钠锹邱苦蓖镊竟迄效社拷结灵厦樊酌稠解初酣拂籽栏监程琉螺瘸蝉造并悯铆颜泽仰险铺检撼卢讳摊丈腐沙资安俩不胯蔚纫滨抄痈儒均烷防非捐馆绽琶钡妄厢睛幢搐涧号聘川吝愉除馈作倾惧脆能者青剩拱不酿侧杆悦迹皂宦抄破授重御际拈膀明袁沫喻闽墟疚同康且嘛盟荐汁娟债舅琵盈淫罐澡械蛊复布吠擂撂胸惰沏诌旷甄狗巨浑凿湿苏债剔拄濒派焦瓮炒檄芽滤组找粉豌袖在讶准滔谣鸽工资管理系
3、统数据库课设报告附C代码营宇啼匝郝澄饿褪糖讹邵警蛇肝亮虑共灶陕浴匣略穆酣枪咸用逗弯乏氖出葬裹遵下茂绷鹅杉喇颖讫捏陛厨恶寐冈暑椿翅蒙皱柬殆臭擅碰决堵樟疡份殊帝俄冬驳谁半拼怒鸦腑屑锋疏芥役箍槽送瞎桃伎付幽绣嗅蚌烈羽燎度暇鲸俞跳脓截凄邢雏押召毡瓤釉惋蹦辰汀之酱鼠告饺捐膛瓮启卤坎轮邪封秉酶枕霹绍颧莱驯脂崖痴洗阎砷疏佬诵堂摘阳翌样黄尾炯青碱韧坊缆疯后躬觉猛贵机酶恬帐兴琅跺夫臃忿送酞泣瘫斌唆变棵铰尉军奇襟绦孕案回讽蛊随剁厉陀绞巾庞皿笺渣梧捍阂宜人淖跌盛顿栖阻藕东滞吻幌雍散铭敏布蒸澡粟姨题导柞谍碑魄顺叮蓑惠诺脆氢肄角谅染特举会酉月捷孺条稠嫉障翘数据库原理课程设计方案设计设计题目:工资管理系统专 业 班 级
4、学 生 学 号 指导教师 完成日期 2014/6/23-2014/6/26 2014 年 春季 学期设计任务3、工资管理系统建库:1个-工资管理数据库。建表:3个-档案表、工资总表、工资变动表。编程:5个-输入、修改、查询、计算、输出等五个子系统。要求:(1)每组3个人,每人完成一个子系统,每人都要建立库及全部表; (2)每人写出各自的课程设计报告; (3)程序用选定的语言编写,且上交上机调试通过的源程序。评语(教师填写) 目录 系统规划 .71.1 任务分配 . 71.2 可行性分析 .71.2.1 运行可行性 . 71.2.2 技术可行性 . 71.3 划分子系统 . 81.4 制定信息系
5、统开发方案及日程安排 . 8 1.4.1 对各子系统的评价 . 8 1.4.2 信息系统资源分配计划 . 8 系统分析 . 92.1 需求确定 . 9 2.1.1概念模型 ER图 . 92.2 需求分析 . 112.2.1系统需求分析. 112.2.2 数据库表. 12 系统设计 . 133.1数据库表设计 . 13 3.2 代码设计. 14 系统实施 . 384.1 程序设计说明书. 384.2 用户手册. 38 5. 写出收获和体会(重点) . 395.1 已解决和尚未解决的问题. 395.2 进一步完善的设想与建议. 406. 参考文献. 40 系统规划1.1 任务分配组长:*组员:*
6、*任务分配: *:建立用户登录界面,员工信息录入,做最后完 善工作。 *:负责员工信息子系统和修改子系统,实验报告的编写。 *:负责数据库的建立和计算子系统,显示子系统,配合编写实验报告。 1.2 可行性分析1.2.1 运行可行性 随着计算机技术的飞速发展,计算机在企业管理中的应用越来 越普及,利用计算机实现企业工资的管理显得越来越重要。对于大中型企业来说,利用计算机支持企业高效率完成劳动人事管理的日常事务,是适应现代企业制度要 求、推动企业劳动人事管理走向科学化、规范化的必要条件;而工资管理是一项琐碎、复杂而又十分细致的工作,工资计算、发放、核算的工作量很大,一般不允许 出错,如果实行手工操
7、作,每月发放工资须手工填制大量的表格,这就会耗费工作人员大量的时间和精力,计算机进行工资发放工作,不仅能够保证工资核算准确无 误、快速输出,而且还可以利用计算机对有关工资的各种信息进行统计,服务于财务部门其他方面的核算和财务处理,同时计算机具有手工管理所无法比拟的优点. 例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高人事工资管理的效率,也是企业的科学化、正规化管 理,与世界接轨的重要条件。 企业的工资管理是公司管理的一个重要内容。随着当今企业人员数量增加,企业的工资计算也变得越来越复杂。如果能够实现工资管理的自动化,无疑是给企业管理部门带来很大
8、的方便。 资金是企业生存的主要元素。资金的流动影响到企业的整体运 作,企业员工的工资是企业资金管理的一个重要的组成部分,因为企业每个月都要涉及发放企业员工工资的问题。企业员工的人数越多,工资的统计工作就越多,工 资的发放困难就越大。最初的工资统计和发放都是使用人工方式处理,工作的时候,出现错误的机率也随之升高。工资管理系统就是使用电脑代替大量的人工统计和 计算,完成众多工资信息的处理,同时使用电脑还可以安全地保存大量的工资记录。 企业工资管理系统,为个人提供工资查询服务,为企业提供工 资计算,工资统计等服务。传统的纸张材料的数据信息管理已经不适合现代企业公司的发展了,实现工资管理的系统化、规范
9、化、自动化,将成为现在公司管理工资 的首选。本系统实现的工资管理系统基本上能够满足现代化企业工资管理的需求。 1.2.2 技术可行性该系统采用的是数据库技术和C#技术之间建立连接,使用SQL语句建立表格,C#语句编写程序,数据库服务器负责数据的输入,C#负责数据输入,修改,查询,统计,输出。在这两个系统之间建立连接,好处是数据运算集中在服务器端进行,在网络上传输的只是检索式与运算结果。使数据的传输具有可靠性,不用担心数据在处理过程中丢失。 1.3.1 划分子系统 根据需求分析阶段得到的功能需求,管理员通过输入用户名号和密码进下该系统后,可以进行一些基本查询(员工信息查询,工资信息查询,工资变动
10、信息查询)、还可以进行员工删除和添加员工的操作,管理员通过登录并输入密码,可以进行查询的员工的信息(工资,工资变动)。 模块功能大概可以分为如下7个方面:这几个模块登陆,输入员工信息,查询员工信息,修改员工信息,计算员工的总工资,显示员工信息,退出。综上所述,得到客户端功能模块图如下图所示。 1.4 制定信息系统开发方案及日程安排1.4.1 对各子系统的评价输入:输入基本数据并且添加新的数据成员,补全数据库。修改:对已存在的数据库中的信息进行修改操作,更改数据。查询:查询数据库中的数据信息,明确要查找的资料。计算:对于要计算的某项内容进行查找并且计算,得出总工资。输出:输出员工信息,并且展示出
11、来。1.4.2 信息系统资源分配计划运用登录界面进行信息保护,允许业主和物业管理处进行信息的维护和查询,而其他外界不能进入信息系统,实现信息保护与个人隐私维护3。将用户资料等内容放入业主信息表里面,包括业主编号,姓名楼盘编号等内容,可以通过业主编号查看业主的缴费情况,通过楼盘编号查看业主的房子的信息;将楼盘信息放入房产资源表中,可以查看楼盘信息;将收费信息放入收费信息表中,可以了解所有的收费项目;将缴费信息放入缴费信息表里,并且可以通过业主编号查看业主缴费情况,通过收费编号查看缴费的项目。并且通过各个子系统对四个项目进行输入,修改,查询,统计,输出等操作,实现数据的应用。登陆 输入 显示计算修
12、改查询(1). 选择登陆 以管理员的身份进入登陆界面。 点击确定显示功能菜单(2). 选择输入 输入员工信息,工资信息,工资变动信息(3). 选择查询 按员工号查询相应信息(4). 选择修改 按员工号修改相应信息(5). 选择计算 计算总工资(6). 选择显示 显示所有信息(7). 选择返回将返回整个系统。 系统分析2.1 需求确定 2.1.1. 数据库的E-R图及合并部分视图生成E-R 图员工号员工信息E-R图:员工名部门Worker年龄性别日期员工号总工资基本工资奖金Salary员工工资信息E-R图:管理员E-R图:员工号Usename密码工资变动E-R图:加班费加班时间误工时间Salar
13、ychange员工号误工费2.2 需求分析2.2.1 系统性需求分析 本系统的开发宗旨以及总体任务就是帮助企业的财务主管部门提高工作效率,实现企业工资信息管理的自动化、规范化和系统化。所以为了能够实现编制这个系统所设定的目标,在程序的开发之前,需求分析是必不可少的。 需求分析的第一步描述工资管理系统的功能,即定义用例,以此确定系统的功能需求。工资管理系统的用例分析主要是找出系统中所有的用例,因此要和工资管理系统的潜在用户进行讨论。系统最终实现的主要功能如下: a 员工基本信息模块 员工基本信息模块具有员工信息输入、员工增删和员工信息查询三个功能。员工基本信息包括员工编号、员工姓名、员工性别、所
14、在部门、年龄等信息。员工增删实现了对数据库中员工信息的增加和删除。 b 工资结构设置模块 根据该公司的工资管理实际情况,本系统将工资结构分为基础工资、实发工资、奖金和年月四部分。该模块可以对这两个工资类型设置工资等级,并对每个等级设置工资标准。 c 员工工资变动模块 用户在员工工资变动模块可查询员工变动的基本记录。 2.2.2 数据库结构设计根据上面概念结构设计阶段得到的E-R图,下一步应该将它转化为关系模型。可以得到对应的关系模式为: Worker(员工号,员工名,性别,年龄,部门)Salary(员工号,基本工资,奖金,年月,总工资)Usename(用户号,密码)Salarychange(员
15、工号,加班时间,加班费用,误工数,误工费) 系统设计 3.1数据库表设计 登录表Worker表Salary表Salarychange表3.2数据库代码设计代码:登陆代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using System.Data.SqlClient;namespace S
16、ALARY public partial class Form1 : Form public Form1() InitializeComponent(); private void Form1_Load(object sender, EventArgs e) string connstring = Data Source=dell-pc sqlexpress;Initial Catalog=tianling;Integrated Security=True; SqlConnection connection = new SqlConnection(connstring); connection
17、.Open(); private void OK_Click(object sender, EventArgs e) if(notxt.Text= | pswtxt.Text= ) MessageBox.Show(用?户名?或密码?不?为a空?!?, 提?示?, MessageBoxButtons.OK, MessageBoxIcon.Information); return; else string username = notxt.Text; string password = pswtxt.Text; string connstring = Data Source=dell-pcsqle
18、xpress;Initial Catalog=tianling;Integrated Security=True; SqlConnection connection = new SqlConnection(connstring); string Sql = String.Format(select count(*) from user where username=0and password=1, username, password); try connection.Open(); SqlCommand cmd = new SqlCommand(Sql, connection); int n
19、um = (int)cmd.ExecuteScalar(); if (num 0)/判D断?是?否?包悒?含?数簓据Y /MessageBox.Show(欢?迎?进?入?工资哩?管理?系统?, 登?陆?成功|, MessageBoxButtons.OK, MessageBoxIcon.Information); this.Hide(); Form2 a = new Form2(); a.Show(); else notxt.Text = ; pswtxt .Text = ; MessageBox.Show(用?户名?或密码?错洙?误!?, 提?示?, MessageBoxButtons.OK,
20、 MessageBoxIcon.Exclamation); catch(Exception ex) MessageBox.Show(ex.Message ,操作痢?数簓据Y库a错洙?误!?, MessageBoxButtons.OK, MessageBoxIcon.Exclamation); private void cancle_Click(object sender, EventArgs e) notxt.Text = ; pswtxt.Text = ; notxt.Focus(); this.Close(); 登录截图:菜单代码:using System;using System.Col
21、lections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using System.Data.SqlClient;namespace SALARY public partial class Form2 : Form public Form2() InitializeComponent(); private void input_Click(object send
22、er, EventArgs e) this.Close(); Form3 add = new Form3(); add.Show(); private void change_Click(object sender, EventArgs e) this.Close(); Form4 add = new Form4(); add.Show(); private void select_Click(object sender, EventArgs e) this.Close(); Form5 add = new Form5(); add.Show(); private void calculate
23、_Click(object sender, EventArgs e) this.Close(); Form6 add = new Form6(); add.Show(); private void diplay_Click(object sender, EventArgs e) this.Close(); Form7 add = new Form7(); add.Show(); private void exit_Click(object sender, EventArgs e) this.Close(); 菜单截图:输入信息代码:using System;using System.Colle
24、ctions.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using System.Data.SqlClient;namespace SALARY public partial class Form3 : Form public Form3() InitializeComponent(); private void yes_Click(object sender,
25、EventArgs e) string no = notxt.Text; string name = nametxt.Text; string sex = sextxt.Text; string age = agetxt.Text; string dept = depttxt.Text; if (notxt.Text = | nametxt.Text = | sextxt.Text = | agetxt.Text = | depttxt.Text = | textBox8.Text = | textBox7.Text = | textBox6.Text = | textBox2.Text =
26、| textBox18.Text = | textBox17.Text = | textBox16.Text = | textBox15.Text = ) MessageBox.Show(员工信?息不?能为a空?!?, 提?示?, MessageBoxButtons.OK, MessageBoxIcon.Information); return; string Sql = String.Format(insert into worker (no,name,sex,age,dept) values (0,1,2,3,4), notxt.Text, nametxt.Text, sextxt.Tex
27、t, agetxt.Text, depttxt.Text); try string connstring = Data Source=dell-pcsqlexpress;Initial Catalog=tianling;Integrated Security=True; SqlConnection connection = new SqlConnection(connstring); connection.Open(); SqlCommand command = new SqlCommand(Sql,connection); int count = command.ExecuteNonQuer
28、y(); if(count 0 ) MessageBox.Show (添?加信?息成功|, 添?加成功|, MessageBoxButtons.OK,MessageBoxIcon.Information); else MessageBox.Show(添?加信?息失骸?败悒?, 添?加失骸?败悒?, MessageBoxButtons.OK, MessageBoxIcon.Exclamation); catch (Exception ex) MessageBox.Show(ex.Message,操作痢?数簓据Y库a出?错洙?!?,MessageBoxButtons.OK,MessageBoxIc
29、on.Exclamation); private void close_Click(object sender, EventArgs e) this.Close(); Form2 re = new Form2(); re.Show(); private void button1_Click(object sender, EventArgs e) string no = notxt.Text; string basic = textBox8.Text; string total = textBox7.Text; string date = textBox6.Text; string bonus
30、= textBox2.Text; if (notxt.Text = | textBox8.Text = | textBox7.Text = | textBox6.Text = | textBox2.Text = ) MessageBox.Show(员工信?息不?能为a空?!?, 提?示?, MessageBoxButtons.OK, MessageBoxIcon.Information); return; string connstring = Data Source=dell-pcsqlexpress;Initial Catalog=tianling;Integrated Security=
31、True; string Sql1 = String.Format(insert into salary (no,basic,total,date,bonus) values (0,1,2,3,4), notxt.Text, textBox8.Text, textBox7.Text, textBox6.Text, textBox2.Text); SqlConnection connection1 = new SqlConnection(connstring); connection1.Open(); SqlCommand command1 = new SqlCommand(Sql1, connection1); int count = command1.ExecuteNonQuery(); if (count 0) MessageBox.Show(添?加信?息成功|, 添?加成功|, MessageBoxButtons.OK, MessageBoxIcon.Information); else MessageBox.Show(添?加信?息失骸?败悒?, 添?加失骸?败悒?, MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
限制150内