版权声明:本文为博主原创文章,未经博主允许不得转载。 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();
验证结果正确,这里就不贴图了。