ホームページ > バックエンド開発 > PHPチュートリアル > 先輩、兄弟、特に時間の比較で困っています、助けてください。

先輩、兄弟、特に時間の比較で困っています、助けてください。

WBOY
リリース: 2016-06-13 12:14:56
オリジナル
1041 人が閲覧しました

先輩方、兄弟方、私は時間の比較の問題で悩んでいます、特に助けてください。
出席時間の保存形式の問題。タイムスタンプの保存には bigint を使用しました。
限定: 午前 9 時前と午後 5 時 30 分以降にカードをスワイプした場合は、遅刻または早退していないとみなされます。
スワイプ カード チェックインとスワイプ カード チェックアウトには、サインインとサインアウトという 2 つのテーブルが使用されます。
発生する問題は次のとおりです。
1. ユーザーがカードをスワイプしたときに、遅刻したか早退したかをどのように判断するか。
2. 月末の統計中に、今月の彼の遅刻と早退の記録をすべて取得するにはどうすればよいですか。

時間を比較するのは頭の痛い問題です。先輩方、ご指導いただければ幸いです、ありがとうございました。 thinkphp mysqlを使用します。

データ テーブルは次のように定義されます:

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,
date timestamp not null,
location varchar(100) not null
)DEFAULT charset=utf8;

create table ts_signout
(signid int not null auto_increment Primary key,
wxname varchar(50) not null,
date timestamp not null,
location varchar(100) not null
) DEFAULT charset=utf8;

alter table ts_signin 外部キー (wxname) 参照の追加 ts_user(wxname);
alter table ts_signout add 外部キー (wxname) 参照 ts_user(wxname);

しばらくここで考えてみますので、先輩方のご指導をいただければ幸いです。
------解決策のアイデア----------------------

<br />    	echo date('h', strtotime("2015-01-27 09:01:10")); //9点<br />    	echo date('i', strtotime("2015-01-27 09:01:10"));//01分<br />
ログイン後にコピー

------解決策----------------------
データを記録し、遅刻・早退を同時に判断し、このフィールドには、その日の 9 時のタイムスタンプ
が保存されます: strtotime(date('Y-m-d') . ' 09:00') そして、それを time()
と比較します。 ------ソリューションアイデア----------------------
<br /><br />create table ts_user<br />(wxname varchar(50) not null primary key,<br /> name varchar(50) not null,<br />telnum char(11) not null unique,<br />email varchar(50) unique,<br />address varchar(100)<br />)ENGINE=InnoDB DEFAULT charset=utf8;<br /><br />create table ts_signin<br />(signid int not null auto_increment primary key,<br /> wxname varchar(50) not null,<br /> sdate int(10) not null,<br />chidao int(1) default 0,  // 1迟到,0没有迟到 int或bool 类型都行<br />edate int(10) not null,<br />zaotui int(1) default 0, //1早退,0没有早退, <br />location varchar(100) not null  // 这是干嘛的不知道<br />)DEFAULT charset=utf8;<br />
ログイン後にコピー

カウントを直接選択(chidao) ) as chidaoa from ts_user,ts_signin, where ts_signin .wxname =ts_user.wxname and (1か月の判定)
このように、
毎日1つのデータを追加すると、遅刻または早退がわかります、チェックインがない場合は毎晩12時に更新することを忘れないでください、遅刻または早退としてリストされ、データセグメントを挿入するときはchidaoに直接書き込み、早退の判断
---- --ソリューションアイデア------------------ ----
会社の勤怠管理マシンを設定しましたが、これは比較的複雑な場合もあります。ユーザーに応じて部門と時間グループに分けられますが、一般的に言えば、ユーザーは 1 つの勤怠スケジュール グループにのみ所属できます。

勤怠マシンにも設定があり、いつ出勤と判断され、いつ出勤と判断されるかが勤怠スケジュールの通勤時間に合わせられます。そうでない場合は、彼が遅刻したか早退したかが判断されます。

月末の統計は比較的単純です。たとえば、9:00 に出勤する場合、9 時より前の出欠をすべてリストすることができます。 :01、そして日付を循環します。ちなみに、休日の時間を除くと、当然遅くなります

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート