Maison >base de données >tutoriel mysql >Comment générer des dates consécutives et des affectations de variables dans MySQL

Comment générer des dates consécutives et des affectations de variables dans MySQL

王林
王林avant
2023-06-02 21:55:121572parcourir

1. Dates consécutives de production

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 :

Comment générer des dates consécutives et des affectations de variables dans MySQL

Ç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 ;
Comment générer des dates consécutives et des affectations de variables dans MySQL

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. ; Comment générer des dates consécutives et des affectations de variables dans MySQL

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer