版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、项目4-人力资源管理系统项目来源:湖南科创信息技术股份有限公司随着市场竞争的日趋激烈,人才已成为实现企业自身战略目标的一个非常关键的因素。企业中人心向背和员工对工作的投入程度在很大程度上决定了该企业的兴衰与成败。如何能保持本企业对员工的工作责任感,激励他们的工作热情,减少人才的流失,已成为困扰企业主管和人力资源经理的一个日益尖锐的问题,可以说企业管理从根本上来讲就是对人的管理。现在“公平、公正、合理”的企业管理原则已为不少企业所采纳。但是要实现“公平、公正、合理”绝非易事,它不是仅靠规章制度和政策就可以解决的。通过建立透明、相容、一致、易查和全面的人力资源信息系统,将与人相关的信息统一地管理起
2、来,才有可能为“公平、公正、合理”原则的实现,以及企业在运作和劳资纠纷等方面的风险规避等建立一套科学的保障体系。本章将向读者全面剖析人力资源管理的内容,由此得出人力资源管理系统需求分析和数据建模,并最终演示如何利用Visual Basic.NET完成系统的制作。1 人力资源管理的任务与作用1.1 人力资源管理的任务人力资源管理工作的主要任务有:进行人力资源规划和分析贯彻平等就业机会原则聘任员工从事人力资源开发确定报酬和福利处理员工与劳资关系人力资源规划和分析包括几方面的任务。在进行人力资源规划的过程中,经理人员将预计未来影响劳动力供求的有关因素。人力资源分析要求具备各种相关的信息资料、通信系统
3、和评价系统,它们是从事协调人力资源工作所不可或缺的部分。政府在遵从平等就业机会法规方面的要求,无疑将对所有其他人力资源管理工作产生重大影响。例如,企业在进行战略性人力资源规划时,为贯彻在雇佣少数种族成员和妇女方面的赞助性行为的要求,就必须为雇佣各种各样的雇员留有充分的余地。另外在招聘选拔和培训人员时,所有经理人员都必须遵守平等就业机会法规的要求。聘任员工指选择适合标准要求的相应数量的人员,来填补企业的岗位空缺。职务分析是聘任工作的基础。根据职务分析所得结论,就可以准备工作说明书和职务要求细则,这两项都是在招聘中所需使用的材料。在人员选拔过程中,应特别注意选择最符合要求的员工来填补企业的岗位空缺
4、。员工培训与人力资源开发工作包括想新雇员介绍企业的各种情况、对现有员工进行职业技能培训、鼓励和帮助员工在多方面提高和发展等内容。在职务不断演化和改变的环境下,为了适应技术的变化,企业就必须对员工进行培训和再培训。此外,为迎接未来的挑战,还必须鼓励各级负责人、管理者和所有员工不断有所发展和提高。为此企业一般制定了员工职业发展计划,这种计划的目的,是为那些在企业内寻求自我发展的员工设计出发展的路径,并安排为此所需要的有关活动。为了提高员工的工作成效,企业还应对员工的工作表现进行考核,以确定员工的本职工作究竟做的怎么样。报酬就是通过薪金、奖励和福利等方式来报答为企业工作的员工。企业必须认真设计和不断
5、完善基本工资和薪酬制度。除了工薪以外,越来越多的企业好指定了某些奖励计划,例如利润分享和工作奖励等。但是另一方面,快速增长的福利费用,特别是扶摇直上的医疗的保健费用,仍将继续是一个值得思考和认真对待的重大问题。如果员工和企业双方都想联手共创繁荣,那么管理着和员工就必须卓有成效地处理双方的关系。不论员工是否由工会来代表,企业都必须重视与员工健康、人身安全和财物保障有关的各项工作。为促成企业与员工的良好关系,企业还必须保障员工的各种权利。另外为了使员工如同管理者那样准确地了解企业对员工的期望。企业还必须制定、传达和不断更新人力资源政策和规则。在有工会的企业中,企业还应重视和处理好资方和工会的关系。
6、1.2 人力资源管理系统的作用人力资源管理系统是以先进的软件和高速、大容量的硬件为基础的,新的人力资源管理模式,通过集中式的信息库、自动处理信息、员工自助服务、外协以及服务共享,达到降低成本、提高效率、改进员工服务模式的目的。它通过与企业现有的网络技术相联系,保证人力资源与日新月异的技术环境同步发展。一般来说,可以分为四个部分来理解人力资源管理系统。管理人员角色和目标的改变传统的人力资源管理中,管理人员的绝大部分精力将耗费在繁琐的日常行政事务处理上,而作为企业管理层的参谋角色应该做的咨询和策略制定的工作相对缺乏。通过人力资源管理系统管理人员将决大部分精力放在管理层提供咨询、建议上,而在行政事务
7、上的工作可以由电子化系统完成,只需占用HR人员极少的精力和时间。提供更好的服务人力资源管理系统可以迅速、有效地收集各种信息,加强内部的信息沟通。各种用户可以直接从系统中获得自己所需要的各种信息,并根据相关信息做出决策和相应的行动方案。3. 降低成本人力资源管理系统通过减少人力资源管理工作的操作成本、降低员工流动率、减少通讯费用等途径达到降低企业运作成本的目的。4. 革新管理理念人力资源管理系统的最终目的是达到革新企业的管理理念而不仅仅是改进管理方式、优化人力资源管理。先进技术应用与人力资源管理时,并不仅仅是为了将现有的人力资源工作做的更好,更重要的是,做些对于企业来讲更有效率的事情,成为管理层
8、的决策支持者,为决策提供信息和解决方案。2 功能分析与系统流程图由于篇幅有限,本实例详细介绍如图1所示的功能开发过程,并简化其中各功能所包含的属性,其他功能读者完全可以参照这些功能的开发方法实现。人力资源管理系统人力资源管理系统图1详细介绍的功能模块历史工资历史工资奖励记录历史工资惩罚记录当月工资管理修改明细并计算从历史导入导入到历史图2系统流程图3数据库设计一个基本的人力资源管理系统数据库中包括多张数据表,分别存放相应子功能的数据信息,其中组织机构编码表和职员基本信息表是起关键作用的表,用于存放基础的数据信息。其他涉及组织机构信息和职员信息的数据表,都只记录机构或职员的编号,根据作为外键的编
9、号字段和组织机构编码表或职员基本信息表相对应。因此这2张表和其他数据表间的关系是1:N的关系。本程序共需8张表,用途分别如表1所示。表1 系统数据表及其用途数据表名称数据表用途用户清单保存系统使用者的信息职员基本信息表用于保存企业组织机构的详细信息,包括机构间的层次编码等组织机构编码表用于保存企业员工的基本信息月工资统计表用于保存、计算当月的员工工资个人所得税表用于保存个人所得税的税率数据工资发放历史表用于保存所有月份工资发放的历史职员奖励表用于保存员工的奖励情况职员惩罚表用于保存员工的惩罚情况以下为数据表之间的关系图图3 数据表关系图3.1创建数据库打开SQL Server企业管理器,新建一
10、个数据库,将其命名为hrmbook。后面几小节我们将列出几个重点的数据表的建库脚本。3.2创建“组织机构编码表”CREATE TABLE dbo.组织机构编码表 (内部编号 int IDENTITY (1, 1) NOT NULL ,类别 varchar (100) NULL ,AbsIndex int NULL ,ItemIndex int NULL ,ItemLevel int NULL ,ParentIndex int NULL ,类别号 char (10) NULL ,单位编号 varchar (20) NOT NULL PRIMARY KEY,单位名称 varchar (100) N
11、ULL ,拼音编码 varchar (50) NULL ,单位地址 varchar (100) NULL ,单位电话号码 varchar (50) NULL ,开户银行 varchar (100) NULL ,帐号 varchar (50) NULL ,开户全称 varchar (100) NULL) ON PRIMARYGO3.3创建“职员基本信息表”CREATE TABLE dbo.职员基本信息表 (内部编号 int IDENTITY (1, 1) NOT NULL ,职员编号 varchar (30) NOT NULL PRIMARY KEY,姓名 varchar (20) NOT NU
12、LL ,姓名简码 varchar (10) NULL ,性别 varchar (2) NULL ,出生日期 int NULL ,年龄 int NULL ,籍贯 varchar (50) NULL ,民族 varchar (20) NULL ,文化程度 char (50) NULL ,毕业学校 char (100) NULL ,健康状况 varchar (50) NULL ,婚姻状况 varchar (10) NULL ,身份证号码 varchar (一八) NULL ,家庭电话 varchar (50) NULL ,办公电话 varchar (50) NULL ,手机 varchar (50)
13、 NULL ,电子邮件地址 varchar (50) NULL ,职工账号 varchar (20) NULL ,单位编号 varchar (20) NULL, 备注 varchar (100) NULL ) ON PRIMARYGO3.4创建其他数据表CREATE TABLE dbo.用户清单 (用户编号 char (6) NOT NULL ,部门 char (20) NOT NULL ,姓名 char (10) NOT NULL ,性别 char (2) NOT NULL ,密码 char (10) NULL ) ON PRIMARYGOCREATE TABLE dbo.月工资统计表 (日
14、期 int NULL ,职员编号 varchar (30) Not NULL PRIMARY KEY,基本工资 float NULL DEFAULT (0) ,浮动工资 decimal(26, 2) NULL DEFAULT (0) ,合同补 decimal(26, 2) NULL DEFAULT (0) ,粮副补 decimal(26, 2) NULL DEFAULT (0) ,房补 decimal(26, 2) NULL DEFAULT (0) ,临时补 decimal(26, 2) NULL DEFAULT (0) ,职务工资 decimal(26, 2) NULL DEFAULT (0
15、) ,工龄工资 decimal(26, 2) NULL DEFAULT (0) ,考核工资 decimal(26, 2) NULL DEFAULT (0) ,奖金 decimal(26, 2) NULL DEFAULT (0) ,应发金额合计 decimal(26, 2) NULL DEFAULT (0) ,房租 decimal(26, 2) NULL DEFAULT (0) ,水电费 decimal(26, 2) NULL DEFAULT (0) ,请假扣除 decimal(26, 2) NULL DEFAULT (0) ,考勤扣除 decimal(26, 2) NULL DEFAULT (
16、0) ,罚款 decimal(26, 2) NULL DEFAULT (0) ,住房公积金 decimal(26, 2) NULL DEFAULT (0) ,医疗保险 decimal(26, 2) NULL DEFAULT (0) ,养老保险 decimal(26, 2) NULL DEFAULT (0) ,失业保险 decimal(26, 2) NULL DEFAULT (0) ,生育保险 decimal(26, 2) NULL DEFAULT (0) ,工伤保险 decimal(26, 2) NULL DEFAULT (0) ,应扣金额合计 decimal(26, 2) NULL DEFA
17、ULT (0) ,工资合计 decimal(26, 2) NULL DEFAULT (0) ,个人所得税 decimal(26, 2) NULL DEFAULT (0) ,实发金额 decimal(26, 2) NULL DEFAULT (0) ,发放否 char (10) NULL ,月份 int NULL) ON PRIMARYGOCREATE TABLE dbo.个人所得税表 (编号 int NOT NULL PRIMARY KEY,级数 char (2) NOT NULL ,不计税工资 decimal(26, 2) NOT NULL DEFAULT (800),工资下限 decimal
18、(26, 2) NOT NULL DEFAULT (0),工资上限 decimal(26, 2) NOT NULL DEFAULT (0),个人所得税率 decimal(26, 2) NOT NULL DEFAULT (0),速算扣除数 decimal(26, 2) NOT NULL DEFAULT (0),备注 varchar (50) NULL) ON PRIMARYGOCREATE TABLE dbo.工资发放历史表 (日期 int NULL ,职员编号 varchar (30) NULL ,基本工资 float NULL ,浮动工资 decimal(26, 2) NULL ,合同补 d
19、ecimal(26, 2) NULL ,粮副补 decimal(26, 2) NULL ,房补 decimal(26, 2) NULL ,临时补 decimal(26, 2) NULL ,职务工资 decimal(26, 2) NULL ,工龄工资 decimal(26, 2) NULL ,考核工资 decimal(26, 2) NULL ,奖金 decimal(26, 2) NULL ,应发金额合计 decimal(26, 2) NULL ,房租 decimal(26, 2) NULL ,水电费 decimal(26, 2) NULL ,请假扣除 decimal(26, 2) NULL ,考
20、勤扣除 decimal(26, 2) NULL ,罚款 decimal(26, 2) NULL ,住房公积金 decimal(26, 2) NULL ,医疗保险 decimal(26, 2) NULL ,养老保险 decimal(26, 2) NULL ,失业保险 decimal(26, 2) NULL ,生育保险 decimal(26, 2) NULL ,工伤保险 decimal(26, 2) NULL ,应扣金额合计 decimal(26, 2) NULL ,工资合计 decimal(26, 2) NULL ,个人所得税 decimal(26, 2) NULL ,实发金额 decimal(
21、26, 2) NULL ,发放否 char (10) NULL ,月份 int NULL) ON PRIMARYGOCREATE TABLE dbo.职员奖励表 (序号 int IDENTITY (1, 1) NOT NULL PRIMARY KEY,职员编号 varchar (30) NOT NULL ,奖励类型 varchar (20) NULL ,奖励金额 float NULL DEFAULT (0),是否计入工资 char (10) NULL DEFAULT (否),奖励原因 varchar (50) NULL ,部门意见 varchar (100) NULL ,奖励日期 int NU
22、LL) ON PRIMARYGOCREATE TABLE dbo.职员惩罚表 (序号 int IDENTITY (1, 1) NOT NULL PRIMARY KEY,职员编号 varchar (30) NOT NULL ,惩罚类型 varchar (20) NULL ,惩罚金额 float NULL DEFAULT (0) ,是否计入工资 char (10) NULL DEFAULT (否),惩罚原因 varchar (50) NULL ,部门意见 varchar (100) NULL ,惩罚日期 int NULL) ON PRIMARYGO3.5创建外部关键字ALTER TABLE dbo
23、.月工资统计表 ADD CONSTRAINT FK_月工资统计表_职员基本信息表 FOREIGN KEY (职员编号) REFERENCES dbo.职员基本信息表 (职员编号)GOALTER TABLE dbo.工资发放历史表 ADD CONSTRAINT FK_工资发放历史表_职员基本信息表 FOREIGN KEY (职员编号) REFERENCES dbo.职员基本信息表 (职员编号)GOALTER TABLE dbo.职员奖励表 ADD CONSTRAINT FK_职员奖励表_职员基本信息表 FOREIGN KEY (职员编号) REFERENCES dbo.职员基本信息表 (职员编号
24、)GOALTER TABLE dbo.职员惩罚表 ADD CONSTRAINT FK_职员惩罚表_职员基本信息表 FOREIGN KEY (职员编号) REFERENCES dbo.职员基本信息表 (职员编号)GO3.6创建存储过程系统使用了四个存储过程,分别实现从历史导入工资明细、计算当月工资和工资发放的功能。这些存储过程都在“当月工资管理”模块中使用,可以通过以下的脚本代码创建。if exists (select * from dbo.sysobjects where id = object_id(Ndbo.sf_空数据置0) and OBJECTPROPERTY(id, NIsProce
25、dure) = 1)drop procedure dbo.sf_空数据置0GOif exists (select * from dbo.sysobjects where id = object_id(Ndbo.sf_形成月工资统计表) and OBJECTPROPERTY(id, NIsProcedure) = 1)drop procedure dbo.sf_形成月工资统计表GOif exists (select * from dbo.sysobjects where id = object_id(Ndbo.sf_当月工资统计) and OBJECTPROPERTY(id, NIsProced
26、ure) = 1)drop procedure dbo.sf_当月工资统计GOif exists (select * from dbo.sysobjects where id = object_id(Ndbo.sf_当月工资发放) and OBJECTPROPERTY(id, NIsProcedure) = 1)drop procedure dbo.sf_当月工资发放GO-create procedure sf_空数据置0asbegin transactionupdate 月工资统计表 set 基本工资=0 where 基本工资 is nullupdate 月工资统计表 set 职务工资=0
27、where 职务工资 is nullupdate 月工资统计表 set 工龄工资=0 where 工龄工资 is nullupdate 月工资统计表 set 考核工资=0 where 考核工资 is nullupdate 月工资统计表 set 奖金=0 where 奖金 is nullupdate 月工资统计表 set 应发金额合计=0 where 应发金额合计 is nullupdate 月工资统计表 set 房租=0 where 房租 is nullupdate 月工资统计表 set 水电费=0 where 水电费 is nullupdate 月工资统计表 set 请假扣除=0 where
28、 请假扣除 is nullupdate 月工资统计表 set 罚款=0 where 罚款 is nullupdate 月工资统计表 set 考勤扣除=0 where 考勤扣除 is nullupdate 月工资统计表 set 住房公积金=0 where 住房公积金 is nullupdate 月工资统计表 set 医疗保险=0 where 医疗保险 is nullupdate 月工资统计表 set 养老保险=0 where 养老保险 is nullupdate 月工资统计表 set 应扣金额合计=0 where 应扣金额合计 is nullupdate 月工资统计表 set 失业保险=0 wh
29、ere 失业保险 is nullupdate 月工资统计表 set 个人所得税=0 where 个人所得税 is nullupdate 月工资统计表 set 工资合计=0 where 工资合计 is nullupdate 月工资统计表 set 实发金额=0 where 实发金额 is nullupdate 个人所得税表 set 个人所得税率=0 where 个人所得税率 is nullcommitGO-create procedure sf_当月工资统计asbegin transactiondeclare xmonth intselect xmonth = 日期 from 月工资统计表- 计算
30、奖金update 月工资统计表 set 奖金 = (select sum(奖励金额) from 职员奖励表 as i where i.是否计入工资=是 and i.奖励日期xmonth*100 and i.奖励日期xmonth*100 and i.惩罚日期1 then 个人所得税率/100 else 个人所得税率 end from 个人所得税表 where 工资上限 1 then 个人所得税率/100 else 个人所得税率 end , xgzxx = 工资下限 from 个人所得税表where 工资下限=xgzsxselect xgrsds = xgrsds + (xgzhj-xgzxx)*
31、xslupdate 月工资统计表 set 个人所得税 = xgrsds where current of mycurfetch next from mycur into xzybh,xgzhjENDclose mycurdeallocate mycur- 计算实发工资update 月工资统计表 set 实发金额 = 工资合计-个人所得税commitGO-create procedure sf_形成月工资统计表 x导入工资月份 int, x统计工资月份 intasbegin transactiondelete from 月工资统计表 - 删除已有数据if exists (select * fro
32、m 工资发放历史表 where 日期=x导入工资月份)begin- 从历史倒入insert into 月工资统计表(日期, 职员编号, 基本工资, 浮动工资, 合同补, 粮副补, 房补, 临时补, 职务工资, 工龄工资, 考核工资, 奖金, 应发金额合计, 房租, 水电费,请假扣除, 考勤扣除, 罚款, 住房公积金, 医疗保险, 养老保险, 失业保险, 生育保险, 工伤保险, 应扣金额合计, 工资合计, 个人所得税, 实发金额,发放否, 月份)select x统计工资月份, 职员编号, 基本工资, 浮动工资, 合同补, 粮副补, 房补, 临时补, 职务工资, 工龄工资, 考核工资, 奖金, 应
33、发金额合计, 房租, 水电费, 请假扣除, 考勤扣除, 罚款,住房公积金, 医疗保险, 养老保险, 失业保险, 生育保险, 工伤保险, 应扣金额合计, 工资合计, 个人所得税, 实发金额,发放否, 月份from 工资发放历史表 as h where h.日期=x导入工资月份end- 新的员工,历史没有记录,生成记录insert into 月工资统计表(职员编号,日期) select 职员编号,x统计工资月份from 职员基本信息表 as h where h.职员编号 not in (select 职员编号 from 月工资统计表)- 将空数据置0exec sf_空数据置0- 自动计算工资exe
34、c sf_当月工资统计commitGO- 发放指定职员的工资create procedure sf_当月工资发放 x职员编号 char(10)asbegin transactionupdate 月工资统计表 set 发放否=是 from 月工资统计表where 职员编号=x职员编号insert into 工资发放历史表select * from 月工资统计表where 职员编号=x职员编号delete 月工资统计表 where 职员编号=x职员编号commitGO4代码与界面设计本系统采用多文档窗体程序,每一功能对应一个子窗体。4.1程序运行结果本实例的运行结果如图4所示。选择主菜单中的各菜单
35、项即可进入相应的功能。例如可以选择【薪资福利管理】|【当月工资管理】菜单命令,调出如图5所示的工资管理功能窗体,在其中输入各个工资项明细,单击【计算当月工资】按钮可以计算出工资;其中的工资项明细也可以通过【导入工资历史】按钮从历史数据中导入,从而减轻输入工作的强度;单击工资发放按钮,可以发放选定职员的工资,打印出工资条并将工资发放的记录放入历史。图4 实例运行结果图5 当月工资管理功能窗体4.2创建工程启动Microsoft Visual Studio.NET2003,在主菜单中选择【文件】|【新建】|【项目】命令,弹出【新建项目】对话框没,在【项目类型】列表框中选择【Visual Basic
36、 项目】,然后在【模板】列表框中选择【Window 应用程序】。在【名称】文本框中输入一个合适的方案文件名,选取要存放的位置,然后单击【确定】按钮完成新项目的创建。6.3创建系统主窗体利用系统默认生成的窗体作为主窗体,并将其对应的文件改名为“frmMain.vb”,为其添加主菜单控件以及StatusBar控件,布局如图6所示。图6系统主窗体(2)窗体的属性设置如表2所示。表2 主窗体属性设置对象(控件)名属性取值(说明)frmMainNamefrmMainfrmMainText人力资源管理系统frmMainIsMdiContainerTrueStatusBarText人力资源管理系统(3)窗体
37、的主菜单属性设置如表5所示。表3 窗体主菜单属性设置菜单栏菜单项属性取值(说明)MenuItemDepText机构编制管理MenuItemDepManageText机构设置及编码MenuItemDepInfoText机构详细信息MenuItemPeopleText职员信息管理MenuItemDepPeopleManageText职员信息维护MenuItemPeopleQueryText职员信息查询MenuItemSalaryText薪资福利管理MenuItemPeopleSalaryManageText当月工资计算MenuItemTaxInfoText个人所得税率MenuItemPrizeTe
38、xt工资发放历史MenuItemPunishText职员奖励管理MenuItemSalaryhisText职员惩罚管理(4)添加判断子窗体实例状态的函数GetInstanceState,此函数主要作用是用来实现单击主窗体的某菜单项,如【计算当月工资】只是出现一个计算当月工资窗体。PrivateFunction GetInstanceState(ByVal name AsString) AsBoolean获得frmMain窗体的子窗体的数量Dim i AsInteger = Me.MdiChildren.Length循环判断是否有名为name的子窗体实例For i = 0 ToMe.MdiChi
39、ldren.Length - 1IfMe.MdiChildren(i).Name = name Then存在名为name的子窗体,是子窗体获得焦点并返回TrueMe.MdiChildren(i).Focus()ReturnTrueEndIfNext不存在名为Name的子窗体FalseReturnFalseEndFunction(5)添加采单项MenuItemDepManage的Click事件响应函数。PrivateSub MenuItemDepManage_Click(ByVal sender AsObject, _ByVal e As System.EventArgs) Handles Me
40、nuItemDepManage.Click判断机构设置及编码窗体是是否已经创建If GetInstanceState(frmDepManage) Then机构设置及编码窗体已经创建并返回ExitSubEndIf创建并显示商品资料维护窗体Dim childFrm As frmDepManage = New frmDepManage childFrm.MdiParent = Me childFrm.Show()EndSub4.4创建数据访问模块因为各个窗体均需要对数据库进行访问,可以把对数据库的一些操作通过一个类来实现,这样可以使对数据库的访问更加简单。选择【文件】|【添加新项】命令添加一个名为“
41、DataBase.vb”的类文件。Imports System.DataImports System.Data.SqlClientImports SystemxponentModelPublicClass DataBase实现接口IDisposableImplements IDisposable数据库连接对象Private SqlConn As SqlConnectionPublicShared sConn AsString = Persist Security Info=False;Integrated Security=SSPI;database=hrmbook;server=localh
42、ost;Connect Timeout=30PublicSub Dispose() Implements System.IDisposable.Dispose Dispose(True) GC.SuppressFinalize(True)EndSubProtectedSub Dispose(ByVal disposing AsBoolean)If disposing TrueThenReturnEndIfIf SqlConn IsNothing = FalseThen SqlConn.Dispose() SqlConn = NothingEndIfEndSubPublicSub Open()I
43、f SqlConn IsNothing = TrueThen建立数据库连接对象 SqlConn = New SqlConnection(Me.sConn)打开数据库连接 SqlConn.Open()EndIfEndSubPublicSub Close()如果数据库连接对象不为空则关闭数据库连接If SqlConn IsNothing = FalseThen SqlConn.Close()EndIfEndSubPublicFunction RunSelectSQL(ByVal sSQLString As System.String) As DataViewMe.Open()Dim SqlDS A
44、s DataSet = New DataSetDim SqlDA As SqlDataAdapter = New SqlDataAdapter(sSQLString, Me.SqlConn) SqlDA.Fill(SqlDS)Return SqlDS.Tables(0).DefaultViewEndFunctionPublicFunction RunDelOrInsSQL(ByVal sSQLString As System.String)Me.Open()Dim SqlComm As SqlCommand = New SqlCommand(sSQLString, Me.SqlConn) Sq
45、lComm.ExecuteNonQuery()EndFunctionEndClass4.5 实现机构设置及编码功能本节主要演示如何利用Visual Basic.NET实现机构设置及编码功能。机构设置的编码机构设置及编码功能主要用于实现设置机构的层级关系。新建一个窗体,将其Name属性设置为“frmDepManage”并为其添加如图7所示的控件。图7机构设置及编码窗体(2)部分控件的属性设置如表4所示。表4 机构设置及编码窗体控件属性设置控件类型对象名属性取值(说明)FormfrmDepManageText机构设置及编码TreeViewtrvListDockLeftSplitterSplitte
46、r1DockLeftPanelpanelRightDockFillTextBoxtxbNameTextTextBoxtxbLKindCodeTextTextBoxtxbDepCodeTextTextBoxtxbDepCodeReadOnlyTrueButtonbtnModifyText修改ButtonbtnAddBasText增加为第一级ButtonbtnAddEqlText增加为本级别ButtonbtnAddSubText增加为子级别ButtonbtnSaveText保存修改ButtonbtnDelText删除为frmDepManage类添加如下两个私有变量。Private dvList A
47、s DataView编码位数Private iBits AsInteger = 12选择【文件】【添加新项】命令添加一个名为“TreNodeData.vb”的类文件,并将“TreNodeData.vb”中的内容替换为以下内容。TreeNodeData类是用来保存与某个TreeView节点(TreeNode)相关的数据PublicClass TreeNodeData以下是TreeNodeData六个共有变量Public AbsIndex AsStringPublic ItemIndex AsStringPublic ItemLevel AsStringPublic ParentIndex AsS
48、tringPublic KindCode AsStringPublic DepCode AsStringTreeNodeData类的构造函数SubNew(ByVal sAbsIndex AsString, _ByVal sItemIndex AsString, _ByVal sItemLevel AsString, _ByVal sParentIndex AsString, _ByVal sKindCode AsString, _ByVal sDepCode AsString) AbsIndex = sAbsIndex ItemIndex = sItemIndex ItemLevel = sI
49、temLevel ParentIndex = sParentIndex KindCode = sKindCode DepCode = sDepCodeEndSubEndClass为frmDepManage类添加私有函数InitTree。InitTree是用递归方法初始化TreeView控件的节点PrivateSub InitTree(ByRef nodes As TreeNodeCollection, _ByVal sParentIndex AsString)TryDim tmpNode As TreeNodeDim absIndex AsStringDim dvTemp As DataVie
50、w = dvList.Table.DefaultView选出数据源中ParentIndex为sParentIndex数据行Dim dataRows() As DataRow = _ dvList.Table.Select(ParentIndex = + sParentIndex + )循环添加TreeNodeForEach dr As DataRow In dataRows获得节点所需数据 tmpNode = New TreeNode tmpNode.Text = dr(类别)用TreeNode的Tag属性保存与此节点相关的数据 tmpNode.Tag = CType(New TreeNode
51、Data(dr(AbsIndex), _ dr(ItemIndex), dr(ItemLevel), _ dr(ParentIndex), dr(类别号), dr(单位编号), Object) absIndex = dr(AbsIndex)添加节点 nodes.Add(tmpNode)递归调用 InitTree(nodes(nodes.Count - 1).Nodes, absIndex)NextCatch ex As Exception MessageBox.Show(初始化TreeView失败)EndTryEndSub为窗体frmDepManage的Load事件添加事件响应代码。Priva
52、teSub frmDepManage_Load(ByVal sender AsObject, _ByVal e As System.EventArgs) HandlesMyBase.LoadDim db As DataBase = New DataBaseDim strSQL AsString strSQL = select * from 组织机构编码表 order by absIndex dvList = db.RunSelectSQL(strSQL) db.Dispose()初始化TreeView控件的各个节点 InitTree(trvList.Nodes, -1)EndSub为按钮btn
53、Modify的click事件添加事件响应代码。PrivateSub btnModify_Click(ByVal sender As System.Object, _ByVal e As System.EventArgs) Handles btnModify.Click判断修改条件If txbLKindCode.Text.Trim().Length = 0 _Or txbDepCode.Text.Trim.Length = 0 ThenExitSubEndIf获得当前选中的节点Dim tmpNode As TreeNode = trvList.SelectedNode对编码进行验证Dim sTm
54、p AsString = txbLKindCode.Text.Trim tmpNode = tmpNode.ParentWhile tmpNode IsNothing = False sTmp = CType(tmpNode.Tag, TreeNodeData).KindCode.Trim + sTmp tmpNode = tmpNode.ParentEndWhileIf sTmp.Trim.Length iBits Then编码超长删除节点 trvList.SelectedNode.Remove() MessageBox.Show(编码超长,已被删除!)Else编码符合要求,修改相应节点 t
55、rvList.SelectedNode.Text = txbName.Text.TrimCType(trvList.SelectedNode.Tag, TreeNodeData).KindCode = _ txbLKindCode.Text.Trim()CType(trvList.SelectedNode.Tag, TreeNodeData).DepCode = _ sTmpMe.txbDepCode.Text = sTmpEndIfEndSub为按钮btnAddBss的Click事件添加事件响应代码。PrivateSub btnAddBas_Click(ByVal sender As Sys
56、tem.Object, _ByVal e As System.EventArgs) Handles btnAddBas.ClickIf txbLKindCode.Text.Trim().Length = 0 _Or txbDepCode.Text.Trim.Length = 0 ThenExitSubEndIfDim tmpNode As TreeNodeIf txbLKindCode.Text.Trim.Length iBits Then MessageBox.Show(编码超长,已被删除!)Else tmpNode = New TreeNode(Me.txbName.Text.Trim)
57、trvList.Nodes.Add(tmpNode)设置新增节点的相关数据 tmpNode.Tag = _CType(New TreeNodeData(, tmpNode.Index.ToString, 0, _ -1, Me.txbLKindCode.Text.Trim, _Me.txbLKindCode.Text.Trim), Object)EndIfEndSub为按钮btnAddEql的Click事件添加事件响应代码。PrivateSub btnAddEql_Click(ByVal sender As System.Object, _ByVal e As System.EventArgs
58、) Handles btnAddEql.ClickIf txbLKindCode.Text.Trim().Length = 0 _Or txbDepCode.Text.Trim.Length = 0 ThenExitSubEndIfDim tmpNode As TreeNode = trvList.SelectedNodeDim sTmp AsString = txbLKindCode.Text.Trim tmpNode = tmpNode.ParentWhile tmpNode IsNothing = False sTmp = CType(tmpNode.Tag, TreeNodeData)
59、.KindCode.Trim + sTmp tmpNode = tmpNode.ParentEndWhileIf sTmp.Trim.Length iBits Then MessageBox.Show(编码超长,已被删除!)Else tmpNode = New TreeNode(Me.txbName.Text.Trim) trvList.SelectedNode.Parent.Nodes.Add(tmpNode) tmpNode.Tag = _CType(New TreeNodeData(, tmpNode.Index.ToString, , _ , Me.txbLKindCode.Text.
60、Trim, sTmp), Object)EndIfEndSub为按钮btnAddSub的Click事件添加事件响应代码。PrivateSub btnAddSub_Click(ByVal sender As System.Object, _ByVal e As System.EventArgs) Handles btnAddSub.ClickIf txbLKindCode.Text.Trim().Length = 0 _Or txbDepCode.Text.Trim.Length = 0 ThenExitSubEndIfDim tmpNode As TreeNode = trvList.Sele
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五版房屋买卖合同中的房屋抵押及解押约定3篇
- 二零二五河南事业单位100人招聘项目合同执行标准3篇
- 二零二五版建筑工程项目现场勘察与监测服务合同3篇
- 二零二五版混凝土结构防雷接地施工合同2篇
- 二零二五年度草场承包管理与开发合同范本3篇
- 二零二五版国际贸易实务实验报告与国际贸易实务实训合同3篇
- 二零二五年度虚拟现实(VR)技术研发合同3篇
- 二零二五年度特种货物安全运输服务合同范本2篇
- 二零二五年度体育设施建设与运营管理复杂多条款合同3篇
- 二零二五年度电梯门套安装与安全性能检测合同3篇
- 电线电缆加工质量控制流程
- 提优精练08-2023-2024学年九年级英语上学期完形填空与阅读理解提优精练(原卷版)
- DB4511T 0002-2023 瓶装液化石油气充装、配送安全管理规范
- 企业内部客供物料管理办法
- 妇科临床葡萄胎课件
- 三基三严练习题库与答案
- 传媒行业突发事件应急预案
- 债务抵租金协议书范文范本
- 药学技能竞赛标准答案与评分细则处方
- 小学英语时态练习大全(附答案)-小学英语时态专项训练及答案
- (高清版)JTGT 3360-01-2018 公路桥梁抗风设计规范
评论
0/150
提交评论