关于考勤数据的思考(MySQL)

最近考勤系统老是出错,不知道公司考勤是怎么做的。因为自己对MySQL用的也不多,这里根据自己的想法参考了别人的博客,加上自己的验证。学到了一些收获,在这里记下来。


数据库索引

  • 主键:
    数据库innodb引擎支持不显式指定主键,但是会默认创建一个用户不可见的主键。
  • 联合索引
    联合索引可以是唯一索引,是多个key的联合。
  • on duplicate key
    这是数据库插入时主键或者唯一索引冲突时会具有这个事件

想法与设计(不能用在实际中)

考勤系统最关心的是签到与签退,这里签到是第一次打卡的时间,签退是最后一次打卡的时间。(这么做记录会不全面,不推荐,只做验证用)
这里我们不关心中间打了多少次卡,只记录第一次和最后一次的时间。所以签到只能是“insert ignore into”,签退是“insert into … on duplicate update time=now()”。这里创建表的时候不能指定 primary key,否则主键冲突会发生,从而覆盖签到的值。我们想到的是依靠“uid,批次”作为唯一索引,如果同一天的同一批次有冲突,则更新。

验证

下面是建表操作的一些语句,day指定的是日期、batch指定上下班、time指定具体时间,因为只做验证,语句比较简陋:

建表语句
create
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值