X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=bde%2Fold%2Ftresorerie.sql;fp=bde%2Fold%2Ftresorerie.sql;h=35a51062015cddce1b4fda42818cb10b51f8bb4b;hb=62bd5a01bbcc7b96c4b1dd098415253d14492517;hp=0000000000000000000000000000000000000000;hpb=7630720dd491fa53093743e683d4e05f22d03afd;p=scripts-20-100.git diff --git a/bde/old/tresorerie.sql b/bde/old/tresorerie.sql new file mode 100644 index 0000000..35a5106 --- /dev/null +++ b/bde/old/tresorerie.sql @@ -0,0 +1,16 @@ +# écrit par 20-100 le 16/03/13 (ouais enfin surtout le 17) +# Des requêtes SQL en vrac pour satisfaire Maylis, penser à porter ça sur la NK2015 avec une interface +# pour les tréoriers + +# Avoir les soldes de tout le monde à une date particulière +SELECT pseudo, numcbde, recu, emis, COALESCE(recu, 0)-COALESCE(emis, 0) AS solde FROM (SELECT adherents.pseudo, adherents.numcbde, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND destinataire=adherents.numcbde AND date<'2012-02-22') AS recu, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND emetteur=adherents.numcbde AND date<'2012-02-22') AS emis FROM adherents) AS calculs; + +# Avoir la somme de tous les soldes de tout le monde à cette date : +SELECT sum(solde) FROM (SELECT pseudo, numcbde, recu, emis, COALESCE(recu, 0)-COALESCE(emis, 0) AS solde FROM (SELECT adherents.pseudo, adherents.numcbde, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND destinataire=adherents.numcbde AND date<'2012-02-22') AS recu, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND emetteur=adherents.numcbde AND date<'2012-02-22') AS emis FROM adherents) AS calculs) AS soldes; +# Oh ! ça fait 0 ! cool hein ? +# Eh ben ça a pas été si trivial que ça… -_- + + +# Le résumé des transactions du BDE, regroupé par type. +SELECT sum(montant*quantite*(CASE WHEN emetteur=destinataire THEN 0 WHEN destinataire=0 THEN 1 ELSE -1 END)) AS total, remarque FROM transactions WHERE valide AND 0 in (emetteur, destinataire) AND date<='2013-02-19' AND date>='2012-02-22' GROUP BY remarque ORDER BY total; +# Attention : penser à changer les *deux* 0 pour le faire sur quelqu'un d'autre.