Maison >base de données >tutoriel mysql >Comment générer des dates consécutives et des affectations de variables dans MySQL
Description : est principalement utilisé pour certaines données statistiques à afficher par ordre chronologique
Si les données de la base de données présentent des lacunes ; Données quotidiennes, mais les statistiques doivent être affichées chaque jour, même si elles sont 0, alors un calendrier doit être généré pour être utilisé
Requête des données de la base de données : #🎜🎜 ; #
SELECT DATE_FORMAT( create_time, '%Y-%m-%d' ) AS date, COUNT(1) AS numb FROM qc_task WHERE create_time>= DATE_SUB(CURDATE(),INTERVAL 1 MONTH) and department_id IN ( SELECT id FROM `vigilante_jinan`.`qc_department` WHERE `area_code` = (@dep_BH) AND `status` = '1' AND dept_level >= (@dep_DJ)) GROUP BY DATE_FORMAT( create_time, '%Y-%m-%d' )
Les données seront publiées le lendemain :
Ça n'aurait-il pas l'air mauvais ? Si vous devez le faire, il est indiqué d'ajouter une commande par 1 desc pour la trier, vous pouvez aussi...Mais même si elle est réglée, l'heure est incohérente ; 🎜#Générer les dates des 7 derniers jours : #🎜 🎜#
// 方法笨,但还是有效的 select DATE_FORMAT(SUBDATE(NOW(), interval (timeList.sj*1460) MINUTE),'%Y-%m-%d') as 'datetime' from (SELECT @num:=@num+1 as sj from (SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5 UNION SELECT 6 UNION SELECT 7) t, -- (SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5 UNION SELECT 6 UNION SELECT 7) t1, -- 假如嫌弃生成的少,打来这个就行 (SELECT @num:=0) y) as timeList
Heure générée :
#🎜🎜 #Utilisation après génération :
-- 生成后左右链接即可,但主表要为时间表 SELECT f.datetime, t.numb FROM (SELECT DATE_FORMAT( create_time, '%Y-%m-%d' ) AS date, COUNT(1) AS numb FROM qc_task WHERE create_time>= DATE_SUB(CURDATE(),INTERVAL 1 MONTH) and department_id IN ( SELECT id FROM `vigilante_jinan`.`qc_department` WHERE `area_code` = (@dep_BH) AND `status` = '1' AND dept_level >= (@dep_DJ)) GROUP BY DATE_FORMAT( create_time, '%Y-%m-%d' )) t right join (select DATE_FORMAT(SUBDATE(NOW(), interval (timeList.sj*1460) MINUTE),'%Y-%m-%d') as 'datetime' from (SELECT @num:=@num+1 as sj from (SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5 UNION SELECT 6 UNION SELECT 7) t, (SELECT @num:=0) y) as timeList) f on t.date = f.datetime ;Après utilisation :
# 🎜🎜#
Voici la base de données Il n'y a pas de données...vous ne pouvez donc pas voir l'affichage de la quantité2 Assignation des variables
Vous voyez là. y a-t-il beaucoup de symboles @ dans le premier, n'est-ce pas ? Ce sont toutes des variables. Si l'instruction de requête est insérée, l'instruction de requête entière sera trop volumineuse et sera très longue... donc certaines choses peuvent être divisées. ;
Par exemple, dans l'instruction de base de données de requête : #🎜🎜 #
Jetons un coup d'oeil à leurs vrais visages :
# 查询部门区域编号 SELECT @dep_BH:=(SELECT area_code FROM qc_department WHERE dept_name = "历下区"); # 查询部门等级 SELECT @dep_DJ:=(SELECT dept_level FROM qc_department WHERE dept_name = "历下区");
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!