温馨提示×

温馨提示×

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

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

数据库设计的方法是什么

发布时间:2021-10-26 15:18:42 来源:亿速云 阅读:284 作者:iii 栏目:编程语言

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

数据库设计

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

<!-- 查询今天是否打卡-->     <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;     }

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

向AI问一下细节

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

AI