数据库设计的方法是什么

发布时间:2021-10-26 15:18:42 作者:iii
来源:亿速云 阅读:314

本篇内容主要讲解“数据库设计的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“数据库设计的方法是什么”吧!

数据库设计

1. 为什么要设计数据库

2. 根据需求设计数据库

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

实现思路

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

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

数据库设计的方法是什么

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

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

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

<!-- 查询今天是否打卡-->     <select id="selectClockinIsexit" resultType="ClockinLog">         SELECT * FROM clockin_log where name = #{name} and pid = #{pid}                    and LEFT(dtime,10) = LEFT(NOW(),10)     </select>  <!-- 查询昨天是否打卡-->     <select id="selectClockinYesterdayIsexit" resultType="ClockinLog">           SELECT * FROM clockin_log where name = #{name} and pid = #{pid}            and LEFT(dtime,10)=LEFT(#{dtime},10)     </select>  既由 2020-10-10T10:30:51  得到  2020-10-10

主要代码

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

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

// 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<ClockinCount> wrapper = new LambdaQueryWrapper<>();         wrapper.eq(ClockinCount::getName,name).eq(ClockinCount::getPid,Integer.parseInt(pid));         ClockinCount one = clockinCountService.getOne(wrapper);          LambdaQueryWrapper<ClockinProject> 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<ClockinCount> 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<ClockinCount> 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;     }

到此,相信大家对“数据库设计的方法是什么”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. 万能数据库设计方法探索
  2. 数据库设计(一)——数据库设计

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

数据库

上一篇:epub如何转换成mobi

下一篇:word遇到问题需要关闭的解决方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》