实训报告(第四组)

一. 需求说明书

1.需求概述

  • 1.1 项目背景

该考勤管理系统是为了解决员工考勤管理而设计的,目的是建立一个能够实现企业考勤管理系统的智能化管理,提高考勤管理系统效率,工作人员能够在各个岗位上的工作状态得到及时的反馈,因而在一个系统内实现尽可能多的功能,满足工作环境的各种需求。

  • 1.2 系统目的

  • (1)提供简单、方便的操作
  • (2)通过考勤管理系统实现,使企业的考勤管理更加科学规范
  • (3)提高考勤管理的透明度和效率。

2.功能模块图

功能模块图.png

3.其他需求

有以下四点
①具有友好的用户界面
②人机界面友好,操作简单
③界面适应屏幕
④界面加上公司LOGO

4.系统网络拓扑图

系统网络拓扑图.png

5.系统不足之处

该软件在c#上开发所以只能运行在windows系统上,并且windows要有.NET 框架。#一.识别实体
1.员工:工号、姓名、性别、部门、年龄、职位
2.打卡机:编号、位置

二.考勤系统E-R图

ER图.png

三.数据表
数据表.PNG

四.数据序表

1.员工


员工.PNG

2.打卡机


打卡机.PNG

3.打卡
打卡.PNG

五.考勤系统功能实现——登录

5.1效果图

登录界面设计.gif

5.2实现代码

 try
                {
                    // 连接数据库
                    sqlConn.Open();

                    // 构造命令发送给数据库
                    String sqlStr = "select * from employee where ID=@id and PASSWORD=@pwd";
                    SqlCommand cmd = new SqlCommand(sqlStr, sqlConn);

                    // 注意是用用户ID登录,而不是用户名,用户名可能会重复
                    cmd.Parameters.Add(new SqlParameter("@id", this.textBox1.Text.Trim()));
                    cmd.Parameters.Add(new SqlParameter("@pwd", this.textBox2.Text.Trim()));

                    SqlDataReader dr = cmd.ExecuteReader();

                    // 如果从数据库中查询到记录,则表示可以登录
                    if (dr.HasRows)
                    {
                        dr.Read();

                        staffinfo.userId = int.Parse(dr["ID"].ToString());
                        staffinfo.userName = dr["NAME"].ToString();
                        staffinfo.userPwd = dr["PASSWORD"].ToString();
                        staffinfo.usergender = dr["GENDER"].ToString();
                        staffinfo.userRole = dr["ROLE"].ToString();


                        MessageBox.Show(staffinfo.userRole + "登录成功");

                        if (staffinfo.userRole == "职员")
                        {
                            // 显示收银员主界面
                            Form3 Form3 = new Form3();
                            Form3.Show();

                            // 隐藏登录界面
                            this.Hide();
                        }

                        if (staffinfo.userRole == "管理员")
                        {
                            // 显示库管员主界面
                            Form4 Form4 = new Form4();
                            Form4.Show();

                            // 隐藏登录界面
                            this.Hide();
                        }
                    }
                    else
                    {
                        MessageBox.Show("用户名或密码错误", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
                    }
                }
                catch (Exception exp)
                {
                    MessageBox.Show("访问数据库错误:" + exp.Message);
                }
                finally
                {
                    sqlConn.Close();
                }
            }


5.3注意事项

(1)连接到数据库, 写入数据
(2)用用户ID登录,而不是用户名,用户名可能会重复

六.考勤系统功能实现——注册

6.1效果图

注册界面.png

6.2实现代码

        private void menuStrip1_ItemClicked(object sender, ToolStripItemClickedEventArgs e)
        {

        }

        private void 统计打卡记录ToolStripMenuItem_Click(object sender, EventArgs e)
        {
            zhuce recordForm = new zhuce();

            recordForm.Show();
        }

6.3注意事项

(1)连接到数据库,实现注册界面登录 写入数据

七.考勤系统功能实现——打卡

7.1效果图

打卡.png

7.2实现代码

 第一步:  // 初始化串口参数
                serialPort1.DataBits = 8;
                serialPort1.BaudRate = 115200;
                serialPort1.Parity = Parity.None;
                serialPort1.StopBits = StopBits.One;
第二步: /// 读取卡号
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void bt_Reader_Click(object sender, EventArgs e)
        {
            // 检测端口是否开启
            if (!serialPort1.IsOpen)
            {
                MessageBox.Show("串口未打开!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return;
            }
第三步:// 寻卡
            cards = SearchCards();

            // 判断到的卡片数量
            if (!(cards.Count > 0))
            {
                MessageBox.Show("未寻到卡!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return;
            }

            string number = ReadSingleBlock(
                ISO15693CardHandler.CovertEndian(cards[0].ID), "00"
                );

            // 判断是否读取成功
            if (number.Equals("-1"))
            {
                MessageBox.Show("读取失败!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return;
            }
第四步:            // 判断是否寻到卡
            if (!(timerCards.Count > 0))
            {
                lastNumber = "";
                return;
            }

            string number = ReadSingleBlock(
                ISO15693CardHandler.CovertEndian(timerCards[0].ID), "00"
                );

第五步:  // 判断是否与上一个卡一致
            if (lastNumber.Equals(number))
            {
                return;
            }
            lastNumber = number;
}
第六步:     // 记录
            recordSQL(number);
        }

7.3注意事项

(1)记得连接到数据库

八.考勤系统功能实现——查询

8.1效果图

查询界面.gif

8.2实现代码

 // 连接字符串,注意与实际环境保持一致
            String connStr = ConfigurationManager.ConnectionStrings["kaoqin"].ConnectionString;
            SqlConnection sqlConn = new SqlConnection(connStr);
            try
            {
                // 连接数据库
                sqlConn.Open();

                // 构造命令
                String sqlStr = "select * from record ";

                // 添加查询条件
                if (!this.comboBox1.Text.Trim().Equals(""))
                {
                    sqlStr += "where employee_id='"+ this.comboBox1.Text.Trim() + "'";
                }

          
                

                SqlCommand cmd = new SqlCommand(sqlStr, sqlConn);

                // 将该查询过程绑定到DataAdapter
                SqlDataAdapter adp = new SqlDataAdapter();
                adp.SelectCommand = cmd;

                // 将DataSet和DataAdapter绑定
                DataSet ds = new DataSet();
                // 自定义一个表(MyGoods)来标识数据库的GOODS表
                adp.Fill(ds, "mydata");

                // 指定DataGridView的数据源为DataSet的MyGoods表
                this.dataGridView1.DataSource = ds.Tables["mydata"];
            }
            catch (Exception exp)
            {
                MessageBox.Show("访问数据库错误:" + exp.Message);
            }
            finally
            {
                sqlConn.Close();
            }
        }
        }
    }

8.3注意事项

(1)连接到数据库,访问数据库数据
(2)选择条件,查询考勤记录

九.考勤系统功能实现——统计

9.1效果图

统计界面.gif

9.2实现代码

  try
            {
                // 连接数据库
                sqlConn.Open();

                // 构造命令,统计一个部门中有哪些员工工作时间不满540分钟
                String sqlStr = @"select t4.department, t4.name, t3.date, t3.start_time, t3.end_time, t3.diff from (
                                    select t1.employee_id, t1.date, t1.time as start_time, t2.time as end_time, datediff(n,t1.time,t2.time) as diff 
                                    from record t1
                                    inner join record t2 
                                    on t1.date = t2.date 
                                    and t1.employee_id=t2.employee_id 
                                    and t1.machine_id=1 
                                    and t2.machine_id=2
                                    and t1.date>=@start
                                    and t1.date<=@end
                                ) t3, employee t4 where t3.employee_id=t4.id and t3.diff<540 and t4.department=@department";
                SqlCommand cmd = new SqlCommand(sqlStr, sqlConn);

                cmd.Parameters.Add(new SqlParameter("@start", this.start));
                cmd.Parameters.Add(new SqlParameter("@end", this.end));
                cmd.Parameters.Add(new SqlParameter("@department", this.department));

                // 将该查询过程绑定到DataAdapter
                SqlDataAdapter adp = new SqlDataAdapter();
                adp.SelectCommand = cmd;

                // 将DataSet和DataAdapter绑定
                DataSet ds = new DataSet();
                // 自定义一个表(MyAttendance)来标识数据库的record表
                adp.Fill(ds, "MyAttendance");

                // 指定DataGridView的数据源为DataSet的record表
                this.dgv_Detail.DataSource = ds.Tables["MyAttendance"];
            }
            catch (Exception exp)
            {
                MessageBox.Show("访问数据库错误:" + exp.Message);
            }
            finally
            {
                sqlConn.Close();
            }
        }

9.3注意事项

(1)连接到数据库,写出合适的选择语句,列出必要条件

十.项目发布

10.1过程步骤

第一步:编写出格式
发布.png

第二步:在相关界面放入此代码
关于1.PNG

第三步:发布
发布1.png

第四步:查看相关信息
关于.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352