自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

來(lái),你們想要的打卡功能

開發(fā) 后端
打卡在生活中還是應(yīng)用挺多的,比如上班打卡,健身打卡,學(xué)習(xí)打卡...等等,實(shí)際上打卡功能開發(fā)是挺容易的,讓我們來(lái)一起實(shí)現(xiàn)它吧,讓我們自己用著自己開發(fā)的功能吧!

前言

你的世界多數(shù)情況下充滿了混沌和單調(diào),你的身體雖然不胖但并不會(huì)讓你感覺(jué)到那么有力量;你的過(guò)往乏善可陳,充斥著很多傷心與自我否定,你過(guò)往的未來(lái)也沒(méi)有驚喜在場(chǎng)。你想要一場(chǎng)新生,想要一次脫胎換骨,沒(méi)有行動(dòng),一切都是空想,依舊忍受痛苦與弱小。一點(diǎn)一滴的積累,才能感受飛輪轉(zhuǎn)起來(lái)時(shí)的酣暢淋漓,才會(huì)有氣勢(shì)如虹的力量 ,一點(diǎn)一滴的積累就是需要一個(gè)打卡的功能。

[[346092]]

打卡在生活中還是應(yīng)用挺多的,比如上班打卡,健身打卡,學(xué)習(xí)打卡...等等,實(shí)際上打卡功能開發(fā)是挺容易的,讓我們來(lái)一起實(shí)現(xiàn)它吧,讓我們自己用著自己開發(fā)的功能吧!

為什么寫一篇打卡的功能性文章吶?

公司一個(gè)系統(tǒng)需要實(shí)現(xiàn)的一個(gè)小小功能,也是為了方便日后進(jìn)行回顧以及優(yōu)化,特此記錄下來(lái),話不多說(shuō)我們來(lái)實(shí)現(xiàn)它吧。

數(shù)據(jù)庫(kù)設(shè)計(jì)

1. 為什么要設(shè)計(jì)數(shù)據(jù)庫(kù)

  • 節(jié)省數(shù)據(jù)的存儲(chǔ)空間
  • 保證數(shù)據(jù)的完整性
  • 方便根據(jù)數(shù)據(jù)庫(kù)進(jìn)行系統(tǒng)的開發(fā)

2. 根據(jù)需求設(shè)計(jì)數(shù)據(jù)庫(kù)

  • 打卡功能
  • 日志表(打卡用戶,打卡項(xiàng)目編號(hào),打卡時(shí)間) 這個(gè)表中的打卡項(xiàng)目這個(gè)字段是非必須的,添加這個(gè)字段只是為了方便日后的擴(kuò)展,其他兩個(gè)字段都是必須的
  • 項(xiàng)目表(項(xiàng)目編號(hào),項(xiàng)目名稱,創(chuàng)建時(shí)間) 這個(gè)表是非必須的,只是為了方便日后的擴(kuò)展,可加可不加
  • 統(tǒng)計(jì)表(項(xiàng)目編號(hào),總打卡數(shù),連續(xù)打卡數(shù),打卡用戶,打卡時(shí)間) 這個(gè)表中的字段除了項(xiàng)目編號(hào)這個(gè)字段不是必須的,其他都是必須要的基本字段,
  • 我這樣設(shè)計(jì)三張表只是為了方便以后的擴(kuò)展使用,除了項(xiàng)目表,其他兩張表都是最基礎(chǔ)的必須要的
  • 首先創(chuàng)建一個(gè)數(shù)據(jù)庫(kù) clockin CHARACTER SET:指定數(shù)據(jù)庫(kù)采用的字符集,utf8不能寫成utf-8 COLLATE:指定數(shù)據(jù)庫(kù)字符集的排序規(guī)則,utf8的默認(rèn)排序規(guī)則為
    1. utf8_general_ci(通過(guò)show character set查看) drop database if EXISTS clockin ; create database clockin CHARACTER SET utf8 COLLATE utf8_general_ci; 
  • sql 語(yǔ)句如下
    1. DROP TABLE IF EXISTS `clockin_count`; 
    2. CREATE TABLE `clockin_count` ( 
    3.   `id` int(11) NOT NULL AUTO_INCREMENT, 
    4.   `pid` int(11) DEFAULT NULL COMMENT '打卡項(xiàng)目', 
    5.   `sum` int(11) DEFAULT NULL COMMENT '打卡總次數(shù)', 
    6.   `cloop` int(11) DEFAULT NULL COMMENT '打卡連續(xù)次數(shù)', 
    7.   `name` varchar(25) COLLATE utf8_bin DEFAULT NULL COMMENT '打卡人', 
    8.   `dtime` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP, 
    9.   PRIMARY KEY (`id`) 
    10. ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
    11.  
    12. DROP TABLE IF EXISTS `clockin_log`; 
    13. CREATE TABLE `clockin_log` ( 
    14.   `id` int(11) NOT NULL AUTO_INCREMENT, 
    15.   `name` varchar(25) COLLATE utf8_bin DEFAULT NULL COMMENT '打卡人', 
    16.   `pid` int(11) DEFAULT NULL COMMENT '打卡項(xiàng)目', 
    17.   `dtime` datetime DEFAULT NULL COMMENT '打卡時(shí)間', 
    18.   PRIMARY KEY (`id`) 
    19. ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
    20.  
    21. DROP TABLE IF EXISTS `clockin_project`; 
    22. CREATE TABLE `clockin_project` ( 
    23.   `id` int(11) NOT NULL AUTO_INCREMENT, 
    24.   `pid` int(11) NOT NULL, 
    25.   `project` varchar(25) COLLATE utf8_bin NOT NULL, 
    26.   `dtime` datetime DEFAULT NULL, 
    27.   PRIMARY KEY (`id`) 
    28. ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin

3. 理解清楚數(shù)據(jù)表之間的映射關(guān)系

  • clockin_log : 日志表,存儲(chǔ)用戶的每天打卡日志信息,表的數(shù)據(jù)更新率比較高,特此提出來(lái),作為單獨(dú)的表使用
  • clockin_project:項(xiàng)目表,在什么項(xiàng)目上的打卡,不是非必要的,只是為了方便日后的擴(kuò)展使用,而添加的
  • clockin_count:統(tǒng)計(jì)表,統(tǒng)計(jì)日志表中用戶的打卡信息,數(shù)據(jù)相對(duì)比較少,提取出來(lái)更加直觀,查詢數(shù)據(jù)用的比較頻繁

實(shí)現(xiàn)思路

首先進(jìn)行判斷項(xiàng)目是否存在,存在才能進(jìn)行打卡,接著判斷今天是否已打卡,如果今天沒(méi)打卡則插入數(shù)據(jù),然后判斷昨天是否打卡,

昨天如果打卡了則連續(xù)天數(shù),總天數(shù)都加一,若昨天沒(méi)打卡,則連續(xù)天數(shù)設(shè)為一,總天數(shù)加一,思維導(dǎo)圖如下:

來(lái),你們想要的打卡功能

這里主要就是sql語(yǔ)句的編寫,我這里主要用到了sql中的 LEFT語(yǔ)法 ,對(duì)應(yīng)了oracle中的substr(),主要是用來(lái)判斷今天昨天是否打卡

語(yǔ)法: ==LEFT (ARG,LENGTH)== ARG源數(shù)據(jù),LENGTH個(gè)字符串,ARG可以是CHAR或BINARY STRING

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

  1. <!-- 查詢今天是否打卡--> 
  2.     <select id="selectClockinIsexit" resultType="ClockinLog"> 
  3.         SELECT * FROM clockin_log where name = #{name} and pid = #{pid} 
  4.                    and LEFT(dtime,10) = LEFT(NOW(),10) 
  5.     </select> 
  6.  
  7. <!-- 查詢昨天是否打卡--> 
  8.     <select id="selectClockinYesterdayIsexit" resultType="ClockinLog"> 
  9.           SELECT * FROM clockin_log where name = #{name} and pid = #{pid} 
  10.            and LEFT(dtime,10)=LEFT(#{dtime},10) 
  11.     </select> 
  12.  
  13. 既由 2020-10-10T10:30:51  得到  2020-10-10 

主要代碼

這里我用到了 MybatisPlus,具體使用可以參照

這里的Result是我定義了一個(gè)結(jié)果集包含 code —— 狀態(tài)碼,msg —— 返回消息 ,data —— 數(shù)據(jù)信息

  1. // name 用戶名 pid 項(xiàng)目編號(hào)    
  2. public Result clock(String name,String pid){ 
  3.  
  4.         // 返回的數(shù)據(jù)類型 
  5.         Result<Object> result = new Result<>(); 
  6.  
  7.         // 得到昨天的日期 
  8.         Calendar calCalendar.getInstance(); 
  9.         cal.add(Calendar.DATE,-1); 
  10.         Date yesterday=cal.getTime(); 
  11.  
  12.         // 判斷今天是否打卡 
  13.         Boolean isexit = clockinLogService
  14.                 selectClockinIsexit(name, Integer.parseInt(pid)); 
  15.  
  16.         LambdaQueryWrapper<ClockinCount> wrapper = new LambdaQueryWrapper<>(); 
  17.         wrapper.eq(ClockinCount::getName,name).eq(ClockinCount::getPid,Integer.parseInt(pid)); 
  18.         ClockinCount one = clockinCountService.getOne(wrapper); 
  19.  
  20.         LambdaQueryWrapper<ClockinProject> wrapper1 = new LambdaQueryWrapper<>(); 
  21.         wrapper1.eq(ClockinProject::getPid,Integer.parseInt(pid)); 
  22.         ClockinProject project = clockinProjectService.getOne(wrapper1); 
  23.  
  24.         //打卡項(xiàng)目是否存在 
  25.         if (!StringUtils.isEmpty(project)){ 
  26.             if (isexit){// 判斷今天是否打卡 
  27.                 result.setRetCode(Result.ERROR); 
  28.                 result.setRetMsg("今日已打卡"); 
  29.                 result.setRowData(one); 
  30.                 return result; 
  31.             }else { 
  32.                 // 記錄打卡信息 
  33.                 ClockinLog clockinLog = new ClockinLog(); 
  34.                 clockinLog.setName(name).setPid(Integer.parseInt(pid)).setDtime(LocalDateTime.now()); 
  35.                 boolean save = clockinLogService.save(clockinLog); 
  36.                 if(save){//是否插入數(shù)據(jù)成功 
  37.                     Boolean yesterdayIsexit = clockinLogService
  38.                             selectClockinYesterdayIsexit(name, Integer.parseInt(pid), yesterday); 
  39.                     System.err.println("yesterdayIsexit->"+yesterdayIsexit); 
  40.                     if (yesterdayIsexit){  //判斷昨天有沒(méi)有打卡 
  41.                         System.err.println("昨天打卡了"); 
  42.                         // 更新打卡次數(shù) 
  43.                         ClockinCount cc = new ClockinCount(); 
  44.                         LambdaUpdateWrapper<ClockinCount> updateWrapper = new LambdaUpdateWrapper<>(); 
  45.                         updateWrapper.eq(ClockinCount::getPid,Integer.parseInt(pid)).eq(ClockinCount::getName, name); 
  46.                         cc.setSum(one.getSum()+1).setCloop(one.getCloop()+1); 
  47.                         clockinCountService.update(cc,updateWrapper); 
  48.                     }else { 
  49.                         if (!StringUtils.isEmpty(one)){  // 統(tǒng)計(jì)表中用戶存在否 
  50.                             // 更新打卡次數(shù) 
  51.                             ClockinCount cc = new ClockinCount(); 
  52.                             LambdaUpdateWrapper<ClockinCount> updateWrapper = new LambdaUpdateWrapper<>(); 
  53.                             updateWrapper.eq(ClockinCount::getPid,Integer.parseInt(pid)).eq(ClockinCount::getName, name); 
  54.                             cc.setSum(one.getSum()+1).setCloop(1); 
  55.                             clockinCountService.update(cc,updateWrapper); 
  56.                         }else { 
  57.                             // 插入數(shù)據(jù)信息 
  58.                             ClockinCount cc = new ClockinCount(); 
  59.                             cc.setCloop(1).setName(name).setPid(Integer.parseInt(pid)).setSum(1).setDtime(LocalDateTime.now()); 
  60.                             clockinCountService.save(cc); 
  61.                         } 
  62.                     } 
  63.                     one = clockinCountService.getOne(wrapper); 
  64.                     result.setRetCode(Result.SUCCESS); 
  65.                     result.setRetMsg("成功"); 
  66.                     result.setRowData(one); 
  67.                     return result; 
  68.                 } 
  69.             } 
  70.         }else { 
  71.             result.setRetCode(Result.ERROR); 
  72.             result.setRetMsg("失敗"); 
  73.             result.setRowData("打卡項(xiàng)目不存在"); 
  74.         } 
  75.         return null; 
  76.     } 

總結(jié)

本文主要介紹了用Java寫一個(gè)打卡功能的主要過(guò)程,打卡主要是記錄了一個(gè)人階段性的努力,如果自己的自我規(guī)劃學(xué)習(xí)能力不高,自我督促能力不強(qiáng),那么這個(gè)打卡功能就可以完美的解決督促自己進(jìn)行學(xué)習(xí)以及其他事情。以上就是本篇文章的主要代碼以及思路。

本文授權(quán)轉(zhuǎn)載自公眾號(hào)「良許Linux」。良許,世界500強(qiáng)外企Linux開發(fā)工程師,公眾號(hào)里分享大量Linux干貨,歡迎關(guān)注!

 

責(zé)任編輯:趙寧寧 來(lái)源: 今日頭條
相關(guān)推薦

2020-12-11 07:23:03

微信更新移動(dòng)應(yīng)用

2021-01-03 17:46:51

微信微信7.0.22移動(dòng)應(yīng)用

2015-05-04 11:26:52

2025-01-24 08:04:48

2013-12-12 13:13:10

Windows 9

2018-05-23 20:48:26

iOS 12分屏果粉

2019-10-24 14:15:52

Python工具數(shù)據(jù)

2012-08-17 09:44:27

Windows Pho

2010-07-09 11:27:40

思科標(biāo)準(zhǔn)

2021-10-14 14:00:44

996加班工作

2020-09-02 08:52:16

地圖Echarts可視化

2010-03-29 16:11:57

無(wú)線上網(wǎng)卡

2020-05-20 11:17:29

緩存服務(wù)器地址

2020-08-07 16:18:38

JavaScriptC++Python

2021-04-20 10:52:23

人工智能智能家居科技

2021-09-24 15:46:35

低碳未來(lái)

2019-11-27 15:09:41

開源技術(shù) 軟件

2015-10-13 09:32:38

WiFi打卡考勤

2013-08-26 09:31:47

技術(shù)面試
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)