时间:2021-07-01 10:21:17 帮助过:19人阅读
strtotime("2015-01-26 09:00:00");strtotime("2015-01-26 17:30:00");
strtotime("2015-01-26 09:00:00");strtotime("2015-01-26 17:30:00");
// 获取时间的小时, H是24小时制 根据H来判断是否迟到,至于5点半的,再比较分钟就可以了吧,这样就不用每天都要生成时间戳了date('H', $timestamp)
echo date('h', strtotime("2015-01-27 09:01:10")); //9点 echo date('i', strtotime("2015-01-27 09:01:10"));//01分
记录数据的同时判断迟到和早退,并作为一个新字段保存
当天9点的时间戳:strtotime(date('Y-m-d') . ' 09:00')跟time()对比就可以了
create table ts_user(wxname varchar(50) not null primary key, name varchar(50) not null,telnum char(11) not null unique,email varchar(50) unique,address varchar(100))ENGINE=InnoDB DEFAULT charset=utf8;create table ts_signin(signid int not null auto_increment primary key, wxname varchar(50) not null, sdate int(10) not null,chidao int(1) default 0, // 1迟到,0没有迟到 int或bool 类型都行edate int(10) not null,zaotui int(1) default 0, //1早退,0没有早退, location varchar(100) not null // 这是干嘛的不知道)DEFAULT charset=utf8;
我设置够公司的考勤机,比较复杂,还可以根据用户分部门,分时间组;但是整体来说,一个用户只可能属于一个考勤排班组。
考勤机还有一个设置,就是什么时候开始判断为上班,什么时候开始判断为下班;然后配上考勤排班里面的上下班时间,就不然判断他是否迟到或早退。
月末统计比较简单,知道获取到所有符合考勤的时间,比如你9:00上班,你就把所有上班考勤早于9:01分的考勤全部列出来了,然后循环一下日期,顺便去除放假的时间,自然而然的,迟到就出来了
随便看看,我不说话
create table ts_user(wxname varchar(50) not null primary key, name varchar(50) not null,telnum char(11) not null unique,email varchar(50) unique,address varchar(100))ENGINE=InnoDB DEFAULT charset=utf8;create table ts_signin(signid int not null auto_increment primary key, wxname varchar(50) not null, sdate int(10) not null,chidao int(1) default 0, // 1迟到,0没有迟到 int或bool 类型都行edate int(10) not null,zaotui int(1) default 0, //1早退,0没有早退, location varchar(100) not null // 这是干嘛的不知道)DEFAULT charset=utf8;