J'ai besoin d'écrire des requêtes pour trouver nouveaux utilisateurs et utilisateurs réguliers.Trouver des utilisateurs de la table qui existait il y a plus de 24 heures
nouveaux utilisateurs sont ceux dont UUID apparus dans les dernières 24 heures (à partir de maintenant moins la requête de temps est tiré) dans table2
et n'a pas été là avant.
les utilisateurs réguliers sont ceux dont l'uuid est apparu au dernier jour dans table2
et y était également au moins une fois au cours des 3 derniers jours. En outre, seuls les enregistrements avec id > 10
et ip != 2
doivent être pris en compte.
table1
est une table temporaire contenant des dates. Je ne suis pas capable de comprendre comment y parvenir avec l'aide de jointures. Aidez-moi, s'il vous plaît.
table2
+----+---------------------+------+------+ | id | ts | uuid | ip | +----+---------------------+------+------+ | 1 | 2010-01-10 00:00:00 | uid1 | 5 | | 2 | 2010-01-10 00:00:00 | uid2 | 14 | | 3 | 2010-01-10 00:00:00 | uid3 | 11 | | 4 | 2010-01-11 00:00:00 | uid4 | 16 | | 5 | 2010-01-11 00:00:00 | uid5 | 4 | | 6 | 2010-01-13 00:00:00 | uid6 | 2 | | 7 | 2010-01-10 00:00:00 | uid1 | 1 | | 8 | 2010-01-11 00:00:00 | uid2 | 10 | | 9 | 2010-01-12 00:00:00 | uid1 | 1 | | 10 | 2010-01-13 00:00:00 | uid4 | 1 | | 11 | 2010-01-09 21:00:00 | uid1 | 1 | | 12 | 2010-01-09 21:30:00 | uid1 | 2 | | 13 | 2010-01-10 05:00:00 | uid2 | 3 | | 14 | 2010-01-10 12:00:00 | uid1 | 1 | | 15 | 2010-01-10 12:00:00 | uid3 | 1 | | 16 | 2010-01-10 21:00:01 | uid1 | 7 | | 17 | 2010-01-11 01:00:00 | uid2 | 14 | | 18 | 2010-01-11 05:00:00 | uid2 | 11 | | 19 | 2010-01-11 17:59:00 | uid4 | 13 | | 20 | 2010-01-11 06:00:00 | uid5 | 12 | | 21 | 2010-01-11 18:01:00 | uid1 | 14 | | 22 | 2010-01-12 23:05:00 | uid4 | 17 | | 23 | 2010-01-13 12:01:23 | uid6 | 13 | +----+---------------------+------+------+ 23 rows in set (0.00 sec)
table1
+------------+ | ts | +------------+ | 2010-01-10 | | 2010-01-11 | | 2010-01-12 | | 2010-01-13 | +------------+ 4 rows in set (0.00 sec)
sortie en cas de nouveaux utilisateurs prises à 18:00
+------------+-------+
| ts | users |
+------------+-------+
| 2010-01-10 | 3 |
| 2010-01-11 | 2 |
| 2010-01-12 | 0 |
| 2010-01-13 | 1 |
+------------+-------+
4 rows in set (0.00 sec)
table MySQL décharge
DROP TABLE IF EXISTS `table1`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `table1` (
`ts` date NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
/*!40101 SET character_set_client = @saved_cs_client */;
INSERT INTO `table1` VALUES ('2010-01-10'),('2010-01-11'),('2010-01-12'),('2010-01-13');
DROP TABLE IF EXISTS `table2`;
CREATE TABLE `table2` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`ts` datetime DEFAULT NULL,
`uuid` varchar(20) DEFAULT NULL,
`ip` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=24 DEFAULT CHARSET=latin1;
/*!40101 SET character_set_client = @saved_cs_client */;
INSERT INTO `table2` VALUES (1,'2010-01-10 00:00:00','uid1',5),(2,'2010-01-10 00:00:00','uid2',14),(3,'2010-01-10 00:00:00','uid3',11),(4,'2010-01-11 00:00:00','uid4',16),(5,'2010-01-11 00:00:00','uid5',4),(6,'2010-01-13 00:00:00','uid6',2),(7,'2010-01-10 00:00:00','uid1',1),(8,'2010-01-11 00:00:00','uid2',10),(9,'2010-01-12 00:00:00','uid1',1),(10,'2010-01-13 00:00:00','uid4',1),(11,'2010-01-09 21:00:00','uid1',1),(12,'2010-01-09 21:30:00','uid1',2),(13,'2010-01-10 05:00:00','uid2',3),(14,'2010-01-10 12:00:00','uid1',1),(15,'2010-01-10 12:00:00','uid3',1),(16,'2010-01-10 21:00:01','uid1',7),(17,'2010-01-11 01:00:00','uid2',14),(18,'2010-01-11 05:00:00','uid2',11),(19,'2010-01-11 17:59:00','uid4',13),(20,'2010-01-11 06:00:00','uid5',12),(21,'2010-01-11 18:01:00','uid1',14),(22,'2010-01-12 23:05:00','uid4',17),(23,'2010-01-13 12:01:23','uid6',13);
Maintenant * c'est * comment poser une question DB. Effacer, avec des exemples de données prêts à copier-coller. –
Excepté: À quoi sert 'table2'? Est-ce pour limiter la plage de dates pour laquelle vous obtenez cette info? –
En fait, vous avez mal étiqueté vos tables. Quel est le tableau des dates (table2 dans votre texte, table1 dans l'échantillon) pour? –