百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

来,你们想要的打卡功能

moboyou 2025-03-11 14:34 23 浏览

前言

你的世界多数情况下充满了混沌和单调,你的身体虽然不胖但并不会让你感觉到那么有力量;你的过往乏善可陈,充斥着很多伤心与

自我否定,你过往的未来也没有惊喜在场。你想要一场新生,想要一次脱胎换骨,没有行动,一切都是空想,依旧忍受痛苦与弱小。一点

一滴的积累,才能感受飞轮转起来时的酣畅淋漓,才会有气势如虹的力量 ,一点一滴的积累就是需要一个打卡的功能。

打卡在生活中还是应用挺多的,比如上班打卡,健身打卡,学习打卡...等等

实际上打卡功能开发是挺容易的,让我们来一起实现它吧,让我们自己用着自己开发的功能吧

为什么写一篇打卡的功能性文章呐?

公司一个系统需要实现的一个小小功能,也是为了方便日后进行回顾以及优化,特此记录下来,话不多说我们来实现它吧。

数据库设计

1,为什么要设计数据库

  • 节省数据的存储空间
  • 保证数据的完整性
  • 方便根据数据库进行系统的开发

2,根据需求设计数据库

  • 打卡功能
  • 日志表(打卡用户,打卡项目编号,打卡时间) 这个表中的打卡项目这个字段是非必须的,添加这个字段只是为了方便日后的扩展,其他两个字段都是必须的
  • 项目表(项目编号,项目名称,创建时间) 这个表是非必须的,只是为了方便日后的扩展,可加可不加
  • 统计表(项目编号,总打卡数,连续打卡数,打卡用户,打卡时间) 这个表中的字段除了项目编号这个字段不是必须的,其他都是必须要的基本字段,
  • 我这样设计三张表只是为了方便以后的扩展使用,除了项目表,其他两张表都是最基础的必须要的
  • 首先创建一个数据库 clockin CHARACTER SET:指定数据库采用的字符集,utf8不能写成utf-8 COLLATE:指定数据库字符集的排序规则,utf8的默认排序规则为utf8_general_ci(通过show character set查看) drop database if EXISTS clockin ; create database clockin CHARACTER SET utf8 COLLATE utf8_general_ci;
  • sql 语句如下
DROP TABLE IF EXISTS `clockin_count`;
CREATE TABLE `clockin_count` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `pid` int(11) DEFAULT NULL COMMENT '打卡项目',
  `sum` int(11) DEFAULT NULL COMMENT '打卡总次数',
  `cloop` int(11) DEFAULT NULL COMMENT '打卡连续次数',
  `name` varchar(25) COLLATE utf8_bin DEFAULT NULL COMMENT '打卡人',
  `dtime` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

DROP TABLE IF EXISTS `clockin_log`;
CREATE TABLE `clockin_log` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(25) COLLATE utf8_bin DEFAULT NULL COMMENT '打卡人',
  `pid` int(11) DEFAULT NULL COMMENT '打卡项目',
  `dtime` datetime DEFAULT NULL COMMENT '打卡时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

DROP TABLE IF EXISTS `clockin_project`;
CREATE TABLE `clockin_project` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `pid` int(11) NOT NULL,
  `project` varchar(25) COLLATE utf8_bin NOT NULL,
  `dtime` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

3,理解清楚数据表之间的映射关系

clockin_log : 日志表,存储用户的每天打卡日志信息,表的数据更新率比较高,特此提出来,作为单独的表使用

clockin_project:项目表,在什么项目上的打卡,不是非必要的,只是为了方便日后的扩展使用,而添加的

clockin_count:统计表,统计日志表中用户的打卡信息,数据相对比较少,提取出来更加直观,查询数据用的比较频繁

实现思路

首先进行判断项目是否存在,存在才能进行打卡,接着判断今天是否已打卡,如果今天没打卡则插入数据,然后判断昨天是否打卡,

昨天如果打卡了则连续天数,总天数都加一,若昨天没打卡,则连续天数设为一,总天数加一,思维导图如下

这里主要就是sql语句的编写,我这里主要用到了sql中的 LEFT语法 ,对应了oracle中的substr(),主要是用来判断今天昨天是否打卡

语法: ==LEFT (ARG,LENGTH)== ARG源数据,LENGTH个字符串,ARG可以是CHAR或BINARY STRING

例如:left('12345',2) --> 12


    


    

既由 2020-10-10T10:30:51  得到  2020-10-10

主要代码

这里我用到了 MybatisPlus,具体使用可以参照

这里的Result是我定义了一个结果集包含 code —— 状态码,msg —— 返回消息 ,data —— 数据信息

// name 用户名 pid 项目编号   
public Result clock(String name,String pid){

        // 返回的数据类型
        Result<Object> result = new Result<>();

        // 得到昨天的日期
        Calendar cal= Calendar.getInstance();
        cal.add(Calendar.DATE,-1);
        Date yesterday=cal.getTime();

        // 判断今天是否打卡
        Boolean isexit = clockinLogService.
                selectClockinIsexit(name, Integer.parseInt(pid));

        LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>();
        wrapper.eq(ClockinCount::getName,name).eq(ClockinCount::getPid,Integer.parseInt(pid));
        ClockinCount one = clockinCountService.getOne(wrapper);

        LambdaQueryWrapper wrapper1 = new LambdaQueryWrapper<>();
        wrapper1.eq(ClockinProject::getPid,Integer.parseInt(pid));
        ClockinProject project = clockinProjectService.getOne(wrapper1);

        //打卡项目是否存在
        if (!StringUtils.isEmpty(project)){
            if (isexit){// 判断今天是否打卡
                result.setRetCode(Result.ERROR);
                result.setRetMsg("今日已打卡");
                result.setRowData(one);
                return result;
            }else {
                // 记录打卡信息
                ClockinLog clockinLog = new ClockinLog();
                clockinLog.setName(name).setPid(Integer.parseInt(pid)).setDtime(LocalDateTime.now());
                boolean save = clockinLogService.save(clockinLog);
                if(save){//是否插入数据成功
                    Boolean yesterdayIsexit = clockinLogService.
                            selectClockinYesterdayIsexit(name, Integer.parseInt(pid), yesterday);
                    System.err.println("yesterdayIsexit->"+yesterdayIsexit);
                    if (yesterdayIsexit){  //判断昨天有没有打卡
                        System.err.println("昨天打卡了");
                        // 更新打卡次数
                        ClockinCount cc = new ClockinCount();
                        LambdaUpdateWrapper updateWrapper = new LambdaUpdateWrapper<>();
                        updateWrapper.eq(ClockinCount::getPid,Integer.parseInt(pid)).eq(ClockinCount::getName, name);
                        cc.setSum(one.getSum()+1).setCloop(one.getCloop()+1);
                        clockinCountService.update(cc,updateWrapper);
                    }else {
                        if (!StringUtils.isEmpty(one)){  // 统计表中用户存在否
                            // 更新打卡次数
                            ClockinCount cc = new ClockinCount();
                            LambdaUpdateWrapper updateWrapper = new LambdaUpdateWrapper<>();
                            updateWrapper.eq(ClockinCount::getPid,Integer.parseInt(pid)).eq(ClockinCount::getName, name);
                            cc.setSum(one.getSum()+1).setCloop(1);
                            clockinCountService.update(cc,updateWrapper);
                        }else {
                            // 插入数据信息
                            ClockinCount cc = new ClockinCount();
                            cc.setCloop(1).setName(name).setPid(Integer.parseInt(pid)).setSum(1).setDtime(LocalDateTime.now());
                            clockinCountService.save(cc);
                        }
                    }
                    one = clockinCountService.getOne(wrapper);
                    result.setRetCode(Result.SUCCESS);
                    result.setRetMsg("成功");
                    result.setRowData(one);
                    return result;
                }
            }
        }else {
            result.setRetCode(Result.ERROR);
            result.setRetMsg("失败");
            result.setRowData("打卡项目不存在");
        }
        return null;
    }

总结

本文主要介绍了用Java写一个打卡功能的主要过程,打卡主要是记录了一个人阶段性的努力,如果自己的自我规划学习能力不高,自我督

促能力不强,那么这个打卡功能就可以完美的解决督促自己进行学习以及其他事情。以上就是本篇文章的主要代码以及思路。

感谢你可以阅读到这里,希望这个思路能对你能有所帮助,如果你有更好的想法,请评论区留言吧,我们一起讨论研究优化。

> 2020 精选 阿里/腾讯等一线大厂 面试、简历、进阶、电子书 「**良许Linux**」后台回复「**资料**」免费获取

#### 看完的都是真爱,点个赞再走呗?您的「三连」就是良许持续创作的最大动力!

1. 关注**原创**「**良许Linux**」,第一时间获取最新Linux干货!

2. 后台回复【资料】【面试】【简历】获取精选一线大厂面试、自我提升、简历等资料。

3. 关注我的博客:[lxlinux.net](http://www.lxlinux.net)

相关推荐

cvpr 2024|注意力校准用于解缠结的文本到图像个性化

AttentionCalibrationforDisentangledText-to-ImagePersonalization研究背景近年来,大规模文本到图像(T2I)模型取得了显著进展,能...

1080P的显示,4K的享受?NVIDIA DSR游戏实测!

游戏玩家对画质的要求越来越高,因此每到新一代显卡推出的时候,除了游戏性能的提升之外,也会采用提升画质的新技术。NVIDIA最新的Geforce900系列显卡也不例外,一起推出的DSR技术号称可以在1...

「学习OpenCV4」OpenCV线性滤波与非线性滤波总结

本文分享内容来自图书《学习OpenCV4:基于Python的算法实战》,该书内容如下:第1章OpenCV快速入门;第2章图像读写模块imgcodecs;第3章核心库模块core;第4章...

增益映射耦合局部正则化的图像重构算法

朱莉(西安科技大学计算机学院,陕西西安710054)摘要:针对当前的图像重构方法在对多帧超分辨率图像复原时,存在明显的模糊效应与振铃效应的不足,提出增益映射控制耦合局部正则化的图像重构算法。首...

图像处理——5种常见的平滑滤波

平滑滤波是一种简单又常见的图像处理操作。平滑图像的目的有很多,但通常都是为了减少噪声和伪影。在OpenCV中共有5种平滑滤波操作,分别是以下几种:测试代码如下:#include<iostream...

C# 图像处理技术——简单的滤波去噪

在C#中,可以使用System.Drawing命名空间中的类来进行图像处理和滤波去噪操作。以下是一个示例代码,演示如何使用平均滤波器进行简单的去噪处理:usingSystem.Drawing;us...

Java,OpenCV,图像模糊,归一化均值滤波,中值滤波器,高斯模糊

图像模糊图像模糊是图像处理中最简单和常用的操作之一,其主要目的之一是给图像预处理的时候降低图像噪声。图像模糊方法可以总结如下:1、归一化均值滤波器(API为blur())2、高斯滤波器(API为Ga...

带频偏校准的GMSK解调器设计与实现

郑婧怡1,高绍全1,姜汉钧1,张春1,王志华1,2,贾雯2(1.清华大学微电子所,北京100084;2.深圳清华大学研究院,广东深圳518055)摘要:提出了一种在零中频低功耗蓝牙接收机中使用...

图像滤波去噪方法及应用场景

在图像处理中,不同滤波方法针对不同类型的噪声和场景具有特定优势。以下是三种常见滤波器的特点和应用场景总结:1.高斯滤波(GaussianFilter)原理:基于高斯函数的加权平均,对邻域像素进行平...

多体系统动力学仿真软件(DAP)

多体系统动力学仿真软件(DAP)-北京西交智众软件科技有限公司–DAP软件简介DAP(DynamicsAnalysisPlatform)软件,源自西南交通大学沈志云院士带队轨道交通运载系统全国...

精品博文图文详解Xilinx ISE14.7 安装教程

在软件安装之前,得准备好软件安装包,可从Xilinx官网上下载:http://china.xilinx.com/support/download/index.html/content/xilinx/z...

酷睿 Ultra 5 和 Ultra 7,或者i5和i7差距多大?

#我来唠家常#提到ultra,我觉得看这个题目,应该主打轻薄本,或者设计本。分两个问题看:ultra7或者i7的优势,ultra相对老款处理器的优势Ultra7的最大优势是:多了2个大核心,这两个大...

直流-直流(DC-DC)变换电路

直流-直流(DC-DC)变换电路,可以将一种直流电源经过变换电路后输出另一种具有不同输出特性的直流电源,可以是一种固定电压或可调电压的直流电。按照电路拓扑结构的不同,DC-DC变换电路可以分成两种形式...

Energies CL致命错误

期刊基础信息·刊号:ISSN1996-1073·全称:Energies·影响因子:3.2·分区:Q2(能源与燃料类)·版面费:2200瑞士法郎·年发文量:约4500篇CoverLett...

基于心电脉搏信号的无创血压算法研究

洋洋,陈小惠(南京邮电大学自动化学院,江苏南京210023)摘要:针对人体血压无创检测问题,提出了一种基于心电信号(Electrocardiogram,ECG)与光电容积脉搏波(Photople...