Maison > base de données > tutoriel mysql > le corps du texte

Explication détaillée de la façon dont MYSQL implémente la fonction de connexion continue et de repartir de zéro pendant une journée (image)

黄舟
Libérer: 2017-05-28 09:42:25
original
2783 Les gens l'ont consulté

Cet article présente principalement MYSQL pour implémenter la fonction de connexion continue et repartir de zéro après une journée. C'est très bien et a une valeur de référence. Les amis dans le besoin peuvent s'y référer

<.>

1, créez une table de test

CREATE TABLE `testsign` ( 
 `userid` int(5) DEFAULT NULL, 
 `username` varchar(20) DEFAULT NULL, 
 `signtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, 
 `type` int(1) DEFAULT &#39;0&#39; COMMENT &#39;为0表示签到数据,1表示签到日期字典数据&#39; 
) ENGINE=InnoDB DEFAULT CHARSET=utf8
Copier après la connexion

2, insérez les données de test, l'heure d'enregistrement est de 5h21 à 6h5, vous pouvez écrire en direct, mais vous devez écrivez une procédure stockée, je suis paresseux, l'accent devrait être mis sur le code pour obtenir les données de connexion, qui est le troisième point, haha

insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-21 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-22 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-23 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-24 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-25 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-26 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-27 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-28 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-29 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-30 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-05-31 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-06-01 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-06-02 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-06-03 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-06-04 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;72164&#39;,&#39;字典&#39;,&#39;2017-06-05 00:00:00&#39;,&#39;1&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;800675&#39;,&#39;吴小双签到数据&#39;,&#39;2017-05-21 00:00:00&#39;,&#39;0&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;800675&#39;,&#39;吴小双签到数据&#39;,&#39;2017-05-22 00:00:00&#39;,&#39;0&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;800675&#39;,&#39;吴小双签到数据&#39;,&#39;2017-05-23 00:00:00&#39;,&#39;0&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;800675&#39;,&#39;吴小双签到数据&#39;,&#39;2017-05-24 00:00:00&#39;,&#39;0&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;800675&#39;,&#39;吴小双签到数据&#39;,&#39;2017-05-25 00:00:00&#39;,&#39;0&#39;); 
insert into `testsign` (`userid`, `username`, `signtime`, `type`) values(&#39;800675&#39;,&#39;吴小双签到数据&#39;,&#39;2017-05-26 00:00:00&#39;,&#39;0&#39;);
Copier après la connexion

3, RequêteDonnées de connexion continue

SELECT * FROM testsign WHERE TYPE=0 AND 
 DATE_FORMAT(signtime,&#39;%Y%m%d&#39;)>( 
 SELECT IFNULL(MAX(DATE_FORMAT(signtime,&#39;%Y%m%d&#39;)),"20170520") FROM testsign WHERE TYPE=1 
 AND DATE_FORMAT(signtime,&#39;%Y%m%d&#39;)<=DATE_ADD(NOW(), INTERVAL -1 DAY) 
 AND DATE_FORMAT(signtime,&#39;%Y%m%d&#39;) NOT IN ( 
    SELECT DATE_FORMAT(signtime,&#39;%Y%m%d&#39;) FROM testsign WHERE TYPE=0 AND userid=800675 
    ) 
 ) 
 AND DATE_FORMAT(signtime,&#39;%Y%m%d&#39;)<=&#39;20170605&#39; 
 AND userid=800675
Copier après la connexion
Données ininterrompues

Supprimer les données sur le Le 23, à compter du 24, signez pour trois jours consécutifs


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal