《员工管理系统数据库.doc》由会员分享,可在线阅读,更多相关《员工管理系统数据库.doc(59页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-date员工管理系统数据库员工管理系统数据库员工管理系统数据库(sql server)2009-12-27 16:49员工管理系统数据库(sql server) 数据库设置:工资管理系统帐户设置:三个用户 管理员,部门经理(查询本部门员工的信息),员工(权限只能查询本人) 创建数据库设置权限-表1,员工表(员工编号(PK)(FK),姓名,出生日期,身份证号,加入公司日期,登录
2、名,密码,电话,电子邮件,部门编号(FK),员工级别,拥有假期时间,备注)2, 部门表 (部门名称,部门编号(PK)(自动增量),部门经理编号(员工编号),部门描述)3,工资表(工资编号(PK),员工编号,基本工资,应发工资,缺勤早退扣除,津贴,奖金,住房公积金,养老费,是否为单位住房,水电费,工作日期,当前日期,薪资发放当前日期)4,考勤表(考勤编号(PK),员工编号,到达时间,记录者编号(员工编号),考勤类型,日期)5,请假表(请假编号(PK), 员工编号,请假原因,提交时间,请假开始时间,请假结束时间,审核者编号,拒绝申请的理由,申请状态)6,假期表(假期编号(PK),假期具体日期,假期
3、名称,是否为法定假期)各表PK为自动增量,聚集索引表之间的关系 员工表(部门编号)-部门表(部门编号) 员工表(员工编号)-工资表(员工编号) 员工表(员工编号)-考勤表(员工编号) 员工表(员工编号)-请假表(员工编号)表之中的约束1,员工表(check密码为6位以上,check登录名长度大于1,unique登录名唯一)2,工资表(基本工资600,是否为工资住房=是or否,应发工资=基本工资+津贴+奖金-缺勤早退扣除-住房公积金-养老费-水电费)3,考勤表(记录者编号员工编号 and 考勤类型 =“缺勤”or“迟到”or“早退”)4,请假表(员工编号审核者编号 and 申请状态 =“已提交”
4、、“已取消”、“已批准”、“已否决”and 开始时间结束时间)-视图 1,员工基本信息 基表:员工表-(左外联接)-部门表 得到了员工的详细信息,其中包括员工的基本信息、员工的部门信息2, 考勤信息 基表:考勤表-(内联接)-员工表 得到员工的姓名、员工所属部门编号,考勤情况3, 请假信息 基表:请假表-(内联接)-员工表 得到员工的请假申请信息,申请请假状态和请假批准人姓名4,工资信息 基表:员工表-(左外联接)-部门表-(内联接)-工资表 得到员工的详细工资信息5, 基本工资 基表:员工表-(内联接)-工资表 得到员工的基本工资6, 变动工资 基表:员工表-(内联接)-工资表 得到员工基本
5、工资的变动增加信息7,假期信息 基表:假期表 得到假期信息-存储过程1,增加员工 基表:员工表 插入员工表一条记录2, 删除员工 基表:员工表 删除员工表一条记录 根据员工编号3,更新员工信息 基表:员工表 更改员工的基本信息 据员工登录名,密码4,得到用户密码 基表:员工表 input用户名,员工编号output用户密码5,更改密码 基表:员工表 据 员工编号,登录名,原始密码 用户表的密码6, 删除部门全部员工 基表:员工表 7, 增加部门 基表:部门表8,请假申请 基表:请假表 员工插入请假表一条记录9, 更新员工请假状态 基表:请假表 经理或管理员更改请假表中的申请请假状态,或和拒绝申
6、请的理由10,删除请假记录 基表:请假表 删除请假表一条记录 据员工编号和提交时间11,查看员工基本工资 基表:工资表-员工表 据登陆名和密码 查出姓名,基本工资12,更改员工基本工资 基表:工资表-员工表 更改员工的基本工资13,查询员工历史工资信息 基表:员工表-工资表 input员工编号 output得到员工工资具体信息 14,更改员工津贴 基表:员工表-工资表 input员工编号 output更改员工的津贴15,查看部门总发放工资 基表:工资表,员工表,部门表 据部门编号-用户自定义函数1,返回员工工资编号 通过员工编号2,返回员工请假编号 通过员工编号3,返回员工所有请假记录 通过请
7、假编号 4,返回部门成员信息 通过部门名称-触发器1,每次只能删一个员工 定义在在员工表上 否则给出出错信息 2, 更改员工拥有假期 定义在员工表上 当员工请假申请状态是否决时,之前其拥有假期时间已经被减少,否决完成后应该相应恢复其拥有假期时间 3, 员工申请请假状态为批准时 定义在工资表自动将员工表的缺勤扣除项设为应扣的一半4, 更新应发工资 定义在工资表 为基本工资-缺勤早退扣除+奖金+津贴-住房公积金-养老费-水电费-以下是代码 其中约束和之间的关系没建立create database SalaryManagementon (name=SM_data,filename=E:SM.MDF,
8、SIZE=10MB,MAXSIZE=50MB,FILEgrowth=10%)Log On(NAME=SM_log,filename=F:SM.ndf,SIZE = 5MB,MAXSIZE = 10MB,FILEgrowth = 2MB)GO-创建基本表-use SalaryManagementcreate table dbo.员工表( 员工编号 int identity(1,1) not null primary key,姓名 nvarchar(50) NOT NULL,出生日期 datetime NOT NULL ,身份证号 nvarchar(18) not null,加入公司日期 date
9、time NOT NULL ,登录名 nvarchar(20) NOT NULL ,密码 binary(20) not NULL,电话 nvarchar (50) not null,电子邮件 nvarchar (50) NOT NULL ,部门编号 int not NULL,员工级别 int not NULL,拥有假期时间 int not NULL,备注 text null)gocreate table dbo.部门表(部门编号 int IDENTITY (1, 1) NOT NULL primary key,部门名称 nchar (10) not NULL,部门经理编号 int not nu
10、ll,部门描述 text null) gocreate table dbo.工资表(工资编号 int IDENTITY (1, 1) NOT NULL primary key,员工编号 int not null,基本工资 int not null,应发工资 int not null,缺勤早退扣除 int not null,津贴 int not null,住房公积金 int not null,养老费 int not null,是否为单位住房 bit not null,-0表示否,1表示是水电费 int not null,-若是否为单位住房为0,则水电费为0工作日期 datetime NOT NU
11、LL,当前记录日期 datetime NOT NULL,薪资发放日期 datetime NOT NULl)gocreate table dbo.考勤表(考勤编号 int identity(1,1) not null primary key,员工编号 int not null,到达时间 datetime not null,记录者编号 int not null,考勤类型 nvarchar(8) not null,-应为“缺勤”or“迟到”or“早退”日期 datetime not null)gocreate table dbo.请假表(请假编号 int identity(1,1) not null
12、 primary key,员工编号 int not null,请假原因 text not null,提交时间 datetime not null,请假开始时间 datetime not null,请假结束时间 datetime not null,审核者编号 int null,拒绝申请的理由 ntext null,申请状态 nvarchar(6) null )-只能为“已提交”、“已取消”、“已批准”、“已否决”)gocreate table dbo.假期表(假期编号 int identity(1,1) not null primary key,假期具体日期 datetime not null,
13、假期名称 nvarchar(20) not null,是否为法定假期 bit not null)go-创建视图-use SalaryManagementgocreate view dbo.员工基本信息ASSELECT y.员工编号,y.姓名, y.电子邮件, y.电话, y.登录名, y.出生日期, y.部门编号,b.部门名称,y.员工级别,y.拥有假期时间FROM dbo.员工表 as y left outer join dbo.部门表 b on y.部门编号=b.部门编号gocreate view dbo.考勤信息as select k.考勤编号,y.姓名,k.日期,k.考勤类型from
14、考勤表 as k inner join 员工表 as yon k.员工编号=k.员工编号gocreate view dbo.请假信息as select q.请假编号,y.姓名,q.提交时间,q.请假原因,q.申请状态,q.拒绝申请的理由from 请假表 as q inner join 员工表 as yon q.员工编号=y.员工编号gocreate view dbo.工资信息as select y.员工编号,b.部门名称,y.姓名,g.基本工资,g.工资编号,g.应发工资,g.缺勤早退扣除, g.津贴,g.住房公积金,g.养老费,g.水电费,g.薪资发放日期from 工资表 as g inne
15、r join 员工表 as yon g.员工编号 = y.员工编号 left outer join 部门表 as b on y.部门编号 = b.部门编号gocreate view dbo.基本工资as select y.姓名,y.员工编号,g.基本工资from 员工表 as y inner join 工资表 as g on y.员工编号=g.员工编号gocreate view dbo.变动工资asselect y.姓名,y.员工编号,g.工资编号,g.缺勤早退扣除,g.津贴,g.住房公积金,g.养老费,g.水电费,g.薪资发放日期from 员工表 as y inner join 工资表 as
16、 gon y.员工编号 =g. 员工编号 gocreate view dbo.假期信息as select 假期编号,假期具体日期 as 假期日期,假期名称,是否为法定假期from 假期表go-创建存储过程-use SalaryManagement -利用系统函数error来确定每个insert语句是否发生错误,如果发生,事务将会滚.gocreate procedure dbo.增加员工(姓名 nvarchar(50) ,出生日期 datetime ,身份证号 nvarchar(18) ,加入公司日期 datetime ,登录名 nvarchar(20) ,密码 binary(20) ,电话 n
17、varchar (50) ,电子邮件 nvarchar (50) ,部门编号 int ,员工级别 int ,拥有假期时间 int,备注 text = null)asbegin transactioninsert 员工表(姓名,出生日期,身份证号,加入公司日期,登录名,密码,电话,电子邮件,部门编号,员工级别,拥有假期时间, 备注) values (姓名,出生日期,身份证号,加入公司日期,登录名,密码,电话,电子邮件,部门编号,员工级别,拥有假期时间, 备注) if error0begin rollback tran returnendgocreate procedure dbo.删除员工员工编
18、号 intas delete from 员工表where 员工编号=员工编号goCREATE PROCEDURE dbo.更改员工信息( 员工编号 int, 姓名 nvarchar(50) = null, 出生日期 datetime = null, 身份证号 nvarchar(18) = null, 加入公司日期 datetime = null, 电话 nvarchar (50) =null, 电子邮件 nvarchar (50)=null , 部门编号 int =null, 员工级别 int=null , 拥有假期时间 int =null, 备注 text = null) As UPDATE
19、 员工表 Set 员工编号=员工编号, 姓名=姓名, 出生日期=出生日期, 身份证号=身份证号, 电话=电话, 电子邮件=电子邮件, 员工级别=员工级别, 拥有假期时间=拥有假期时间, 备注=备注 WHERE 员工编号 = 员工编号 return RowcountgoCREATE PROCEDURE dbo.得到员工密码(员工编号 int,密码 binary(20) output)As SELECT 密码 = 密码 FROM 员工表 WHERE 员工编号=员工编号 return RowcountgoCreate Procedure dbo.更改密码(登录名 as nvarchar(20),老密
20、码 as binary(20),新密码 as binary(20)ASDeclare 员工编号 as intselect 员工编号=员工编号from 员工表where 登录名=登录名 and 密码=老密码Update 员工表set 密码=新密码where 员工编号=员工编号gocreate procedure dbo.删除部门全部员工 部门编号 intasdelete from 员工表where 部门编号= 部门编号goCreate Procedure dbo.增加部门(部门名称 nchar(10),部门描述 nvarchar(50),部门经理编号 int)ASinsert 部门表(部门名称,
21、部门描述,部门经理编号)values (部门名称,部门描述,部门经理编号)gocreate procedure dbo.请假申请 ( 员工编号 int , 请假原因 text , 提交时间 datetime, 请假开始时间 datetime, 请假结束时间 datetime)as insert 请假表(员工编号,请假原因 ,提交时间,请假开始时间,请假结束时间)values (员工编号, 请假原因,提交时间, 请假开始时间,请假结束时间)gocreate procedure dbo.更新员工请假状态 (员工编号 int, 审核者编号 int, 拒绝申请的理由 ntext = null , 申请
22、状态 nvarchar(6) )asupdate 请假表set 审核者编号 = 审核者编号, 拒绝申请的理由=拒绝申请的理由, 申请状态=申请状态where 员工编号=员工编号gocreate procedure dbo.删除请假记录( 请假编号 int, 员工编号 int, 提交时间 datetime)asdelete from 请假表where 员工编号=员工编号 and 提交时间=提交时间 gocreate procedure dbo.查看基本工资 (登录名 nvarchar, 密码 binary)as -得到员工编号declare 员工编号 as intselect 员工编号=员工编号
23、from 员工表where 登录名=登录名 and 密码=密码-查询员工基本工资select y.姓名,g.基本工资from 员工表 as y inner join 工资表 as gon y.员工编号=g.员工编号where g.员工编号= 员工编号 gocreate procedure dbo.更改员工基本工资 (员工编号 int, 老基本工资 int, 新基本工资 int)asupdate 工资表set 基本工资=新基本工资where 员工编号=员工编号 gocreate procedure dbo.查询员工历史工资信息(员工编号 int, 开始时间 datetime, 结束时间 datetime)ASselect y.姓名, g.工资编号,g.薪资发放日期 as 时间, g.基本工资,g.应发工资, g.缺勤早退扣除,g.津贴,g.住房公积金,g.养老费from 工资表 as gjoin 员工表 as yon g.员工编号=y.员工编号where y.员工编号=员工编号 having g.薪资发放日期 = 开始时间 and g.薪资发放日期 1begin raiserror(一次不能删除超过一个员工!,16,1) rollback transactionendgo-