前言

你的世界多数情况下充满了混沌和单调,你的身体虽然不胖但并不会让你感觉到那么有力量;你的过往乏善可陈,充斥着很多伤心与自我否定,你过往的未来也没有惊喜在场。你想要一场新生,想要一次脱胎换骨,没有行动,一切都是空想,依旧忍受痛苦与弱小。一点一滴的积累,才能感受飞轮转起来时的酣畅淋漓,才会有气势如虹的力量 ,一点一滴的积累就是需要一个打卡的功能。
打卡在生活中还是应用挺多的,比如上班打卡,健身打卡,学习打卡...等等,实际上打卡功能开发是挺容易的,让我们来一起实现它吧,让我们自己用着自己开发的功能吧!
为什么写一篇打卡的功能性文章呐?
公司一个系统需要实现的一个小小功能,也是为了方便日后进行回顾以及优化,特此记录下来,话不多说我们来实现它吧。
数据库设计
1. 为什么要设计数据库
2. 根据需求设计数据库
- utf8_general_ci(通过show character set查看) drop database if EXISTS clockin ; create database clockin CHARACTER SET utf8 COLLATE utf8_general_ci;
 
- 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. 理解清楚数据表之间的映射关系
实现思路
首先进行判断项目是否存在,存在才能进行打卡,接着判断今天是否已打卡,如果今天没打卡则插入数据,然后判断昨天是否打卡,
昨天如果打卡了则连续天数,总天数都加一,若昨天没打卡,则连续天数设为一,总天数加一,思维导图如下:
这里主要就是sql语句的编写,我这里主要用到了sql中的 LEFT语法 ,对应了oracle中的substr(),主要是用来判断今天昨天是否打卡
语法: ==LEFT (ARG,LENGTH)== ARG源数据,LENGTH个字符串,ARG可以是CHAR或BINARY STRING
例如:left('12345',2) --> 12
- SELECT * FROM clockin_log where name = #{name} and pid = #{pid}
 - and LEFT(dtime,10) = LEFT(NOW(),10)
 - SELECT * FROM clockin_log where name = #{name} and pid = #{pid}
 - and LEFT(dtime,10)=LEFT(#{dtime},10)
 - 既由 2020-10-10T10:30:51 得到 2020-10-10
 
主要代码
这里我用到了 MybatisPlus,具体使用可以参照
这里的Result是我定义了一个结果集包含 code —— 状态码,msg —— 返回消息 ,data —— 数据信息
- // name 用户名 pid 项目编号
 - public Result clock(String name,String pid){
 - // 返回的数据类型
 - 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写一个打卡功能的主要过程,打卡主要是记录了一个人阶段性的努力,如果自己的自我规划学习能力不高,自我督促能力不强,那么这个打卡功能就可以完美的解决督促自己进行学习以及其他事情。以上就是本篇文章的主要代码以及思路。
本文授权转载自公众号「良许Linux」。良许,世界500强外企Linux开发工程师,公众号里分享大量Linux干货,欢迎关注!
                标题名称:来,你们想要的打卡功能
                
                网址分享:http://www.csdahua.cn/qtweb/news28/472078.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网