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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u012266559/article/details/82621795

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


数据库索引

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

想法与设计

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

验证

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

建表语句
create table schedule (day int not null, batch int not null, time text not null);
创建唯一索引
create unique index u_idx on schedule(day, batch);
每打一次卡都会执行下面两条语句
insert ignore into schedule (day, batch, time)values (20180911, 0, now());
insert into schedule (day, batch, time) values (20180911, 1, "1" ) on duplicate key update time=now();

验证结果正确,这里就不贴图了。

猜你喜欢

转载自blog.csdn.net/u012266559/article/details/82621795