1、华 北 理 工大 学数据库课程设计说明书设计题目:职工工资管理系统目录1 概述1目的1软件介绍11.1.1 Microsoft Visual Studio 202311.1.2 SQL Server20232系统功能21.1.3 系统说明21.1.4 具体规定31.1.5 系统设立32 需求分析43 概念设计64 逻辑设计94.1关系模式94.2系统功能图105 系统开发流程116 系统使用说明及重要代码137 课程设计体会及心得24参考文献258 附件268.1工资管理模块代码268.2 数据库管理模块代码341 概述目的随着经济的发展和计算机应用的普及,信息技术在管理上越来越进一步而广泛的
2、应用,管理信息系统的实行在技术上已逐步成熟,要高效率地把公司活动有机地组织起来,就必须加强公司管理,即加强对公司内部的各种资源(人、财、物等)的有效管理,建立与自身特点相适应的管理信息系统。采用信息化管理公司是新经济时代的必然趋势,也是公司管理者的迫切需求。现在每个行业都在积极使用现代化的手段,不断改善服务质量,提高工作效率,这些都在很大限度上给公司提出越来越严峻的挑战,对公司提出更高的规定。建设一个科学高效的信息管理系统是解决这一问题的必由之路。职工工资管理作为公司内部的一种财务管理也是如此,由于公司职工人数较多,每一位职工的具体实际情况也不尽相同,各项工资条款的发放,假如没有一个完整的管理
3、系统来进行管理,那么势必会给管理人员带来种种麻烦,因此做出一个工资管理系统之类的管理软件的开发势在必行。在公司选择工资管理系统时,重要存在以下几个方面的规定: (1)对员工档案进行管理。 (2)系统的功能要符合本公司的基本情况。 (3)系统的功能操作要简朴、实用、操作方便,不要出现复杂的操作。软件介绍1.1.1 Microsoft Visual Studio 2023Visual Studio 可以用来创建Windows平台下的 Windows应用程序和网络应用程序,也可以用来创建网络服务、智能设备应用程序和 Office插件。C#是一种精确、简朴、类型安全、面向对象的语言,与VB相比具有较好
4、的优越性和可视性和智能化,提供较多的第三方控件。对于初学者的操作和运用比较简便。并且C#功能极为强大,可实现各种所需的功能。例如:在编辑器中点击某个符号后IDE会自动将相同符号高亮显示。假如程序很长的话可以使用Ctrl+Shift+向下箭头或Ctrl+Shift+向上箭头快速浏览每一个使用该符号的地方。在编写程序过程中假如需要构造新类,程序员可以不打断思绪直接使用该类,然后再重新生成这个类。这样可以提高Dev的开发效率等等,这些功能给用户带来了巨大的方便,让程序员可以更轻松的实现各项想要的功能。1.1.2 SQL Server2023在现今数据的世界里,公司要获得成功和不断发展,他们需要定位重
5、要的数据趋势的愿景。微软的这个数据平台帮助公司满足这些数据爆炸和下一代数据驱动应用程序的需求。微软将继续投入和发展以下的关键领域来支持他们的数据平台愿景:关键任务公司数据平台、动态开发、关系数据和商业智能。SQL SERVER 2023有以下几个优点:(1)可信任的,在今天数据驱动的世界中,公司需要继续访问他们的数据。SQL Server 2023为关键任务应用程序提供了强大的安全特性、可靠性和可扩展性。(2)保护你的信息,简朴的数据加密SQL Server 2023可以对整个数据库、数据文献和日记文献进行加密,而不需要改动应用程序。进行加密使公司可以满足遵守规范和及其关注数据隐私的规定。简朴
6、的数据加密的好处涉及使用任何范围或模糊查询搜索加密的数据、加强数据安全性以防止未授权的用户访问、尚有数据加密。这些可以在不改变已有的应用程序的情况下进行。(3)外键管理,SQL Server 2023为加密和密钥管理提供了一个全面的解决方案。为了满足不断发展的对数据中心的信息的更强安全性的需求,公司投资给供应商来管理公司内的安全密钥。SQL Server 2023通过支持第三方密钥管理和硬件安全模块(HSM)产品为这个需求提供了很好的支持。系统功能1.1.3 系统说明该系统着眼于员工工资业务的实际,对发放工资业务进行了细致的分析、研究,认真分析其业务流程,采用灵活方便的计算解决方式,改变手工操
7、作的繁杂、低效、不宜操作、灵活性差的特点,提高其工作效率和效益。实现员工工资管理业务的制度化、现代化的管理。工资管理系统是为了可以迅速、准确地反映出用户需要的各种信息,及时方便的进行各种检索,从而为决策者做出准确的判断提供强有力的支持。计算机的使用使得公司管理变得更加合理,更加规范,更加科学。1.1.4 具体规定系统数据初始化;员工基本信息数据的查询、添加、修改、删除,员工工资参数的设定与管理;申诉解决;员工考勤的管理;员工个人工资表的查询;员工工资的浏览、修改、添加、删除;系统的维护涉及用户的操作权限、密码修改。1.1.5 系统设立本系统分为两大类用户:员工及管理人员,员工对本人的信息查询和
8、密码的修改并可以提出申诉,管理人员则对员工的信息与自己本人的信息进行数据库的各项操作。2 需求分析随着社会需求和计算机技术的发展,大型公司越来越多,而大型的公司为了满足公司的发展必然需要招收更多的职工,员工的信息管理和工资的发放若由人工解决,效率必将变得低下。所以设计出一个专门的软件来进行管理变得尤为重要,我认为这样的系统应当具有很好的实用性!开发本系统的目的就是立足广大公司的实际,着眼于公司管理的未来发展,规范公司对员工信息和工随着社会需求和计算机技术的发展,大型公司越来越多,而大型的公司为了满足公司的发展必然需要招收更多的职工,员工的信息管理和工资的发放若由人工解决,效率必将变得低下。所以
9、设计出一个专门的软件来进行管理变得尤为重要,我认为这样的系统应当具有很好的实用性!开发本系统的目的就是立足广大公司的实际,着眼于公司管理的未来发展,规范公司对员工信息和工资的管理,提高管理质量,方便员工和管理者的查询,并为此设计该系统。本系统采用结构化设计的方法来实现系统总体功能,提高系统的各项指标,即将整个系统合理的划提成各个功能模块,对的地解决模块之间和模块内部的联系以及和数据库的联系,定义各模块的内部结构,通过对模块的设计和模块之间关系的系统来实现整个系统的功能。该职工工资管理系统的三大系统模块:1、登陆模块(选择身份进行登录)2、前台浏览模块(职工可以查看个人具体信息(工资信息、考勤信
10、息、个人信息),修改个人登陆密码,提出申诉信息)3、后台管理模块(管理员可以进行员工信息管理、员工工资管理、考勤记录管理、申诉解决、数据备分,还原、密码管理)。3 概念设计在用户需求分析的基础上,建立起职工工资管理数据库的概念模型。从系统中我们可以得到下面的关键数据实体对象:职工实体、管理员实体、工资实体、考勤实体,用户实体。将这些实体以及它们之间的联系以实体属性图和实体联系图表达出来。下为职工工资管理系统数据库的E-R图:职工部门 职工号工职位性别年龄姓名 图3-1职工实体E-R图考勤职工号考勤项目考勤处罚日期图3-2考勤实体E-R图工资税务及杂项日期职工号奖金基本工资图3-3工资实体E-R
11、图用户密码职工号图3-4 用户实体E-R图管理员密码用户名图3-5管理员实体E-R图图3-6所有实体E-R图4 逻辑设计4.1关系模式用户名密码(职工号,密码)工资表(职工号,基本工资,税务及杂项扣除,奖金日期)基本信息(职工号,姓名,性别,年龄,职位,部门)管理员(用户名,密码)考勤表(职工号,迟到次数,早退次数,旷工次数,迟到处罚金,早退处罚金,旷工处罚金,日期)申诉表(职工号,申诉信息)4.2系统功能图图4-1系统功能图5 系统开发流程数据库流程图图5-1 数据库流程图选择身份进行登录,员工可以查看个人信息和工资考勤信息并提出申诉,管理人员可以对员工的员工信息进行删除、修改、添加、查询;
12、对员工工资进行汇总、删除、修改、添加、查询;对员工考勤信息进行删除、修改、添加、查询,计算考勤总金额。数据库备份还原,用户密码表管理,申诉解决等。6 系统使用说明及重要代码图6-1 选择身份界面选择身份界面,通过选择身份进行登录。图6-2 登陆界面登录界面,验证用户名密码。图6-3职工主界面职工主界面选择功能。图6-4职工修改密码界面修改密码功能。图6-5 个人信息查询界面自动显示个人基本信息,通过选择日期查询个人工资和考勤记录。图6-6申诉界面假如发现自己信息有误,可以向管理者提出申诉。图6-7管理员主界面。图6-8管理员管理界面修改或添加管理员。图6-9职工信息管理界面通过职工号管理员可以
13、查看个人基本信息,密码信息并可以添加或修改。图6-10职工信息管理界面一次性删除所有与该员工有关的信息。图6-11考勤管理界面通过职工号和日期查询考勤信息和考勤的处罚,并可以修改和新建。图6-12工资管理界面通过职工号和日期查询修改工资信息,并可以新建。图6-13工资管理界面多种方式批量查询工资信息,并可以批量涨(降)薪。(需要选中!)图6-14工资管理界面图6-15工资管理界面可以打印工资条。图6-16申诉解决界面申诉信息解决,可选择行标记已解决和未解决,并可以删除已解决的信息。图6-17数据库管理界面数据库的备份以及还原。(名称与源数据库一致,途径不可太深(如桌面)。7 课程设计体会及心得
14、课程设计是本专业的一项重要的教学任务,就我个人而言编程能力并不是很好,但天天都坚持在机房学习,一开始不知道从哪里下手,慢慢通过网上资料以及书籍和同学的帮助慢慢入手,不断纯熟,完毕一个又一个功能即辛劳又有收获的喜悦,可以说这段日子里有苦有甜,无限出现错误无法解决真的很不舒适而解决错误后那豁然开朗的感觉也很迷人。通过一个月的训练和学习,我学到了许多书本上没有的知识,明白了理论和实际的结合非常重要,必须不断地练习巩固学的知识,加强自己的能力,同时要多去交流分析总结,才干把编程能力提高,无论学习还是生活都没有捷径必须脚踏实地一步一步走过去。参考文献1 (美)内格尔C#高级编程北京:清华大学出版社,20
15、23:157-2162 黄胜忠C#4.0从入门到精通实战版北京:机械工业出版社,2023:376-4003 (英)RobinDewson著董明译SQLServer2023基础教程2023年5月人民邮电出版社4 徐孝凯贺佳英著数据库基础与SQLServer应用开发2023年4月清华大学出版社8 附件8.1工资管理模块代码private void button1_Click(object sender, EventArgs e) try #region 连接数据库 string connectionString = Server=.;database=数据库11;integrated securi
16、ty=true;/定义连接字符串/uid=sa;pwd=123 SqlConnection myconnection = new SqlConnection(connectionString);/链接字符串作为参数 myconnection.Open();/连接到数据库 #endregion string sm = select 基本工资 ,税务及杂项扣除 ,奖金 from 工资表 where 职工号= + textBox1.Text + and 日期 = + comboBox1.Text + ; SqlDataAdapter MYBD = new SqlDataAdapter(sm, myc
17、onnection); DataSet bbs = new DataSet(); MYBD.Fill(bbs, sn); textBox2.Text = bbs.Tablessn.Rows00.ToString();/查询显示 textBox3.Text = bbs.Tablessn.Rows01.ToString(); textBox4.Text = bbs.Tablessn.Rows02.ToString(); catch MessageBox.Show(暂无记录!); textBox1.Text = ; textBox2.Text = ; textBox3.Text = ; textBo
18、x4.Text = ; comboBox1.Text = ; private void button2_Click(object sender, EventArgs e) #region 非空判断 #region 连接数据库 string connectionStrin = Server=.;database=数据库11;integrated security=true;/定义连接字符串/uid=sa;pwd=123 SqlConnection myconnectio = new SqlConnection(connectionStrin);/链接字符串作为参数 myconnectio.Ope
19、n();/连接到数据库 #endregion string po = select * from 工资表 where 日期= + comboBox1.Text + and 职工号=+textBox1.Text +; SqlCommand io = new SqlCommand(po, myconnectio); SqlDataReader myred = io.ExecuteReader();#endregion if (myred.Read() = true)/判断是否为空 myconnectio.Close(); #region 连接数据库 string connectionString
20、= Server=.;database=数据库11;integrated security=true;/定义连接字符串/uid=sa;pwd=123 SqlConnection myconnection = new SqlConnection(connectionString);/链接字符串作为参数 myconnection.Open();/连接到数据库 #endregion #region 修改工资信息 string p = update 工资表 set 税务及杂项扣除= + textBox3.Text + , 基本工资= + textBox2.Text + ,奖金= + textBox4.
21、Text + ; SqlCommand bb = new SqlCommand(p, myconnection); int n = 0; n = bb.ExecuteNonQuery();/修改 MessageBox.Show(保存修改成功!); textBox1.Text = ; textBox2.Text = ; textBox3.Text = ; textBox4.Text = ; comboBox1.Text = ; # endregion else MessageBox.Show(无记录!请先添加!); textBox1.Text = ; textBox2.Text = ; text
22、Box3.Text = ; textBox4.Text = ; comboBox1.Text = ; private void button3_Click(object sender, EventArgs e) 管理员主界面 obj = new 管理员主界面(); obj.Show(); this.Hide(); private void button4_Click(object sender, EventArgs e) try #region 连接数据库 string connectionString = Server=.;database=数据库11;integrated security
23、=true;/定义连接字符串/uid=sa;pwd=123 SqlConnection myconnection = new SqlConnection(connectionString);/链接字符串作为参数 myconnection.Open();/连接到数据库 #endregion string sb = select * from 工资表 where 职工号= + textBox11.Text + and 日期= + comboBox3.Text + ; SqlCommand io = new SqlCommand(sb, myconnection); SqlDataReader my
24、red = io.ExecuteReader(); if (myred.Read() = false)/判断是否为空 myconnection.Close(); string connectionStrin = Server=.;database=数据库11;integrated security=true;/定义连接字符串/uid=sa;pwd=123 SqlConnection myconnectio = new SqlConnection(connectionStrin);/链接字符串作为参数 myconnectio.Open();/连接到数据库 string pp = insert i
25、nto 工资表 values ( + textBox11.Text + , + textBox12.Text + , + textBox13.Text + , + textBox14.Text + , + comboBox3.Text + ); SqlCommand uo = new SqlCommand(pp, myconnectio); int z = 0; z = uo.ExecuteNonQuery(); MessageBox.Show(新建成功!); textBox11.Text = ; textBox12.Text = ; textBox13.Text = ; textBox14.
26、Text = ; comboBox3.Text = ; else MessageBox.Show(已存在记录!); textBox11.Text = ; textBox12.Text = ; textBox13.Text = ; textBox14.Text = ; comboBox3.Text = ; catch MessageBox.Show(存在记录!); private void button5_Click(object sender, EventArgs e) 管理员主界面 obj = new 管理员主界面(); obj.Show(); this.Hide(); private vo
27、id 更新显示_Click(object sender, EventArgs e) try #region 连接数据库 string connectionString = Server=.;database=数据库11;integrated security=true;/定义连接字符串/uid=sa;pwd=123 SqlConnection myconnection = new SqlConnection(connectionString);/链接字符串作为参数 myconnection.Open();/连接到数据库 #endregion if (comboBox2.Text != 年龄)
28、string s = select * from 工资信息 where + comboBox2.Text + = + textBox7.Text + and 日期 = + textBox5.Text + ; SqlCommand j = new SqlCommand(s, myconnection); SqlDataAdapter p = new SqlDataAdapter(j);/qiaoliang DataTable o = new DataTable();/新建表o p.Fill(o);/填充表o dataGridView1.DataSource = o; else string b
29、= select * from 工资信息 where + comboBox2.Text + + textBox7.Text + and 日期 = + textBox5.Text + ; SqlCommand i = new SqlCommand(b, myconnection); SqlDataAdapter l = new SqlDataAdapter(i);/qiaoliang DataTable z = new DataTable();/新建表z l.Fill(z);/填充表z dataGridView1.DataSource = z; catch MessageBox.Show(信息有
30、误!); private void button6_Click(object sender, EventArgs e) try #region 连接数据库 string connectionString = Server=.;database=数据库11;integrated security=true;/定义连接字符串/uid=sa;pwd=123 SqlConnection myconnection = new SqlConnection(connectionString);/链接字符串作为参数 myconnection.Open();/连接到数据库 #endregion for (int
31、 i = dataGridView1.SelectedRows.Count; i 0; i-) string ID = dataGridView1.SelectedRowsi - 1.Cells0.Value.ToString(); string data = dataGridView1.SelectedRowsi - 1.Cells8.Value.ToString(); / Convert.ToInt32(dataGridView1.SelectedRowsi - 1.Cells0.Value); / Convert.ToInt32(dataGridView1.SelectedRowsi -
32、 1.Cells8.Value); string SQL = update 工资信息 set + comboBox4.Text + = + comboBox4.Text + + + textBox6.Text + where 职工号= + ID + and 日期 = + data + ; SqlCommand kk = new SqlCommand(SQL, myconnection); int w = 0; w = kk.ExecuteNonQuery(); / MessageBox.Show(修改成功!); MessageBox.Show(修改成功!); catch MessageBox.
33、Show(输入有误或选中行含空值!); private void button7_Click(object sender, EventArgs e) 管理员主界面 obj = new 管理员主界面(); obj.Show(); this.Hide(); private void button8_Click(object sender, EventArgs e) try #region 连接数据库 string connectionString = Server=.;database=数据库11;integrated security=true;/定义连接字符串/uid=sa;pwd=123 S
34、qlConnection myconnection = new SqlConnection(connectionString);/链接字符串作为参数 myconnection.Open();/连接到数据库 #endregion string b = select * from 工资信息 where 职工号= + tx1.Text + and 日期 = + tx2.Text + ; SqlCommand i = new SqlCommand(b, myconnection); SqlDataAdapter l = new SqlDataAdapter(i);/qiaoliang DataTable z = new DataTable();/新建表z l.Fill(z);/填充表z dataGridView2.DataSource = z;