最近考勤系统老是出错,不知道公司考勤是怎么做的。因为自己对MySQL用的也不多,这里根据自己的想法参考了别人的博客,加上自己的验证。学到了一些收获,在这里记下来。
数据库索引
- 主键:
数据库innodb引擎支持不显式指定主键,但是会默认创建一个用户不可见的主键。 - 联合索引
联合索引可以是唯一索引,是多个key的联合。 - on duplicate key
这是数据库插入时主键或者唯一索引冲突时会具有这个事件
想法与设计(不能用在实际中)
考勤系统最关心的是签到与签退,这里签到是第一次打卡的时间,签退是最后一次打卡的时间。(这么做记录会不全面,不推荐,只做验证用)
这里我们不关心中间打了多少次卡,只记录第一次和最后一次的时间。所以签到只能是“insert ignore into”,签退是“insert into … on duplicate update time=now()”。这里创建表的时候不能指定 primary key,否则主键冲突会发生,从而覆盖签到的值。我们想到的是依靠“uid,批次”作为唯一索引,如果同一天的同一批次有冲突,则更新。
验证
下面是建表操作的一些语句,day指定的是日期、batch指定上下班、time指定具体时间,因为只做验证,语句比较简陋:
建表语句
create