來,你們想要的打卡功能
阿新 • • 發佈:2020-10-13
#### 前言
你的世界多數情況下充滿了混沌和單調,你的身體雖然不胖但並不會讓你感覺到那麼有力量;你的過往乏善可陳,充斥著很多傷心與
自我否定,你過往的未來也沒有驚喜在場。你想要一場新生,想要一次脫胎換骨,沒有行動,一切都是空想,依舊忍受痛苦與弱小。一點
一滴的積累,才能感受飛輪轉起來時的酣暢淋漓,才會有氣勢如虹的力量 ,一點一滴的積累就是需要一個打卡的功能。
打卡在生活中還是應用挺多的,比如上班打卡,健身打卡,學習打卡...等等
實際上打卡功能開發是挺容易的,讓我們來一起實現它吧,讓我們自己用著自己開發的功能吧
> 為什麼寫一篇打卡的功能性文章吶?
公司一個系統需要實現的一個小小功能,也是為了方便日後進行回顧以及優化,特此記錄下來,話不多說我們來實現它吧。
#### 資料庫設計
> 1,為什麼要設計資料庫
- 節省資料的儲存空間
- 保證資料的完整性
- 方便根據資料庫進行系統的開發
> 2,根據需求設計資料庫
- 打卡功能
- 日誌表(打卡使用者,打卡專案編號,打卡時間)
- 這個表中的打卡專案這個欄位是非必須的,新增這個欄位只是為了方便日後的擴充套件,其他兩個欄位都是必須的
- 專案表(專案編號,專案名稱,建立時間)
- 這個表是非必須的,只是為了方便日後的擴充套件,可加可不加
- 統計表(專案編號,總打卡數,連續打卡數,打卡使用者,打卡時間)
- 這個表中的欄位除了專案編號這個欄位不是必須的,其他都是必須要的基本欄位,
- ![](https://img2020.cnblogs.com/other/1218435/202010/1218435-20201013204747248-428918031.png)
- 我這樣設計三張表只是為了方便以後的擴充套件使用,除了專案表,其他兩張表都是最基礎的必須要的
- 首先建立一個數據庫 clockin
- CHARACTER SET:指定資料庫採用的字符集,utf8不能寫成utf-8
- COLLATE:指定資料庫字符集的排序規則,utf8的預設排序規則為utf8_general_ci(通過show character set檢視)
- ```sql
drop database if EXISTS clockin ;
create database clockin CHARACTER SET utf8 COLLATE utf8_general_ci;
```
- sql 語句如下
```mysql
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:統計表,統計日誌表中使用者的打卡資訊,資料相對比較少,提取出來更加直觀,查詢資料用的比較頻繁
#### 實現思路
首先進行判斷專案是否存在,存在才能進行打卡,接著判斷今天是否已打卡,如果今天沒打卡則插入資料,然後判斷昨天是否打卡,
昨天如果打卡了則連續天數,總天數都加一,若昨天沒打卡,則連續天數設為一,總天數加一,思維導圖如下
![](https://img2020.cnblogs.com/other/1218435/202010/1218435-20201013204747936-1618685763.png)
這裡主要就是sql語句的編寫,我這裡主要用到了sql中的 `LEFT`語法 ,對應了oracle中的substr(),主要是用來判斷今天昨天是否打卡
語法: ==LEFT (ARG,LENGTH)== ARG源資料,LENGTH個字串,ARG可以是CHAR或BINARY STRING
例如:`left('12345',2) --> 12`
```sql
既由 2020-10-10T10:30:51 得到 2020-10-10
```
#### 主要程式碼
這裡我用到了 `MybatisPlus`,具體使用可以參照
[MybatisPlus使用]: https://baomidou.com
這裡的`Result`是我定義了一個結果集包含 code —— 狀態碼,msg —— 返回訊息 ,data —— 資料資訊
```java
// name 使用者名稱 pid 專案編號
public Result clock(String name,String pid){
// 返回的資料型別